Fix config options for Android release builds
Using reflection was not a good idea because when the Android App is compiled for release mode, some code optimizations are executed. The fields of the configuration classes were then renamed and the mapping via reflections did not work again. Now everything has an explicit mapping form the untyped HashMap to the class fields and vice versa.
This commit is contained in:
parent
9c7ac0da8f
commit
a7100ae0cc
|
@ -2,7 +2,11 @@ package com.pichillilorenzo.flutter_inappwebview.ChromeCustomTabs;
|
||||||
|
|
||||||
import com.pichillilorenzo.flutter_inappwebview.Options;
|
import com.pichillilorenzo.flutter_inappwebview.Options;
|
||||||
|
|
||||||
public class ChromeCustomTabsOptions extends Options {
|
import java.util.HashMap;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ChromeCustomTabsOptions implements Options {
|
||||||
|
|
||||||
final static String LOG_TAG = "ChromeCustomTabsOptions";
|
final static String LOG_TAG = "ChromeCustomTabsOptions";
|
||||||
|
|
||||||
|
@ -12,4 +16,47 @@ public class ChromeCustomTabsOptions extends Options {
|
||||||
public boolean enableUrlBarHiding = false;
|
public boolean enableUrlBarHiding = false;
|
||||||
public boolean instantAppsEnabled = false;
|
public boolean instantAppsEnabled = false;
|
||||||
|
|
||||||
|
ChromeCustomTabsOptions parse(HashMap<String, Object> options) {
|
||||||
|
Iterator it = options.entrySet().iterator();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry<String, Object> pair = (Map.Entry<String, Object>) it.next();
|
||||||
|
String key = pair.getKey();
|
||||||
|
Object value = pair.getValue();
|
||||||
|
if (value == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (key) {
|
||||||
|
case "addShareButton":
|
||||||
|
addShareButton = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "showTitle":
|
||||||
|
showTitle = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "toolbarBackgroundColor":
|
||||||
|
toolbarBackgroundColor = (String) value;
|
||||||
|
break;
|
||||||
|
case "enableUrlBarHiding":
|
||||||
|
enableUrlBarHiding = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "instantAppsEnabled":
|
||||||
|
instantAppsEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HashMap<String, Object> getHashMap() {
|
||||||
|
HashMap<String, Object> options = new HashMap<>();
|
||||||
|
options.put("addShareButton", addShareButton);
|
||||||
|
options.put("showTitle", showTitle);
|
||||||
|
options.put("toolbarBackgroundColor", toolbarBackgroundColor);
|
||||||
|
options.put("enableUrlBarHiding", enableUrlBarHiding);
|
||||||
|
options.put("instantAppsEnabled", instantAppsEnabled);
|
||||||
|
|
||||||
|
return options;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,10 @@
|
||||||
package com.pichillilorenzo.flutter_inappwebview;
|
package com.pichillilorenzo.flutter_inappwebview;
|
||||||
|
|
||||||
public class InAppBrowserOptions extends Options {
|
import java.util.HashMap;
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class InAppBrowserOptions implements Options {
|
||||||
|
|
||||||
public static final String LOG_TAG = "InAppBrowserOptions";
|
public static final String LOG_TAG = "InAppBrowserOptions";
|
||||||
|
|
||||||
|
@ -13,4 +17,60 @@ public class InAppBrowserOptions extends Options {
|
||||||
public boolean hideTitleBar = false;
|
public boolean hideTitleBar = false;
|
||||||
public boolean closeOnCannotGoBack = true;
|
public boolean closeOnCannotGoBack = true;
|
||||||
public boolean progressBar = true;
|
public boolean progressBar = true;
|
||||||
|
|
||||||
|
public InAppBrowserOptions parse(HashMap<String, Object> options) {
|
||||||
|
Iterator it = options.entrySet().iterator();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry<String, Object> pair = (Map.Entry<String, Object>) it.next();
|
||||||
|
String key = pair.getKey();
|
||||||
|
Object value = pair.getValue();
|
||||||
|
if (value == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (key) {
|
||||||
|
case "hidden":
|
||||||
|
hidden = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "toolbarTop":
|
||||||
|
toolbarTop = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "toolbarTopBackgroundColor":
|
||||||
|
toolbarTopBackgroundColor = (String) value;
|
||||||
|
break;
|
||||||
|
case "toolbarTopFixedTitle":
|
||||||
|
toolbarTopFixedTitle = (String) value;
|
||||||
|
break;
|
||||||
|
case "hideUrlBar":
|
||||||
|
hideUrlBar = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "hideTitleBar":
|
||||||
|
hideTitleBar = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "closeOnCannotGoBack":
|
||||||
|
closeOnCannotGoBack = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "progressBar":
|
||||||
|
progressBar = (boolean) value;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public HashMap<String, Object> getHashMap() {
|
||||||
|
final HashMap<String, Object> options = new HashMap<>();
|
||||||
|
options.put("hidden", hidden);
|
||||||
|
options.put("toolbarTop", toolbarTop);
|
||||||
|
options.put("toolbarTopBackgroundColor", toolbarTopBackgroundColor);
|
||||||
|
options.put("toolbarTopFixedTitle", toolbarTopFixedTitle);
|
||||||
|
options.put("hideUrlBar", hideUrlBar);
|
||||||
|
options.put("hideTitleBar", hideTitleBar);
|
||||||
|
options.put("closeOnCannotGoBack", closeOnCannotGoBack);
|
||||||
|
options.put("progressBar", progressBar);
|
||||||
|
|
||||||
|
return options;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,12 +8,14 @@ import com.pichillilorenzo.flutter_inappwebview.Options;
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
import java.lang.reflect.Field;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import static android.webkit.WebSettings.LayoutAlgorithm.NORMAL;
|
import static android.webkit.WebSettings.LayoutAlgorithm.NORMAL;
|
||||||
|
|
||||||
public class InAppWebViewOptions extends Options {
|
public class InAppWebViewOptions implements Options {
|
||||||
|
|
||||||
public static final String LOG_TAG = "InAppWebViewOptions";
|
public static final String LOG_TAG = "InAppWebViewOptions";
|
||||||
|
|
||||||
|
@ -84,48 +86,304 @@ public class InAppWebViewOptions extends Options {
|
||||||
public Boolean supportMultipleWindows = false;
|
public Boolean supportMultipleWindows = false;
|
||||||
public String regexToCancelSubFramesLoading;
|
public String regexToCancelSubFramesLoading;
|
||||||
|
|
||||||
@Override
|
public InAppWebViewOptions parse(HashMap<String, Object> options) {
|
||||||
public Object onParse(Map.Entry<String, Object> pair) {
|
Iterator it = options.entrySet().iterator();
|
||||||
|
while (it.hasNext()) {
|
||||||
|
Map.Entry<String, Object> pair = (Map.Entry<String, Object>) it.next();
|
||||||
|
String key = pair.getKey();
|
||||||
|
Object value = pair.getValue();
|
||||||
|
if (value == null) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch (key) {
|
||||||
|
case "useShouldOverrideUrlLoading":
|
||||||
|
useShouldOverrideUrlLoading = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "useOnDownloadStart":
|
||||||
|
useOnDownloadStart = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "useOnLoadResource":
|
||||||
|
useOnLoadResource = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "clearCache":
|
||||||
|
clearCache = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "userAgent":
|
||||||
|
userAgent = (String) value;
|
||||||
|
break;
|
||||||
|
case "applicationNameForUserAgent":
|
||||||
|
applicationNameForUserAgent = (String) value;
|
||||||
|
break;
|
||||||
|
case "javaScriptEnabled":
|
||||||
|
javaScriptEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "debuggingEnabled":
|
||||||
|
debuggingEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "javaScriptCanOpenWindowsAutomatically":
|
||||||
|
javaScriptCanOpenWindowsAutomatically = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "mediaPlaybackRequiresUserGesture":
|
||||||
|
mediaPlaybackRequiresUserGesture = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "minimumFontSize":
|
||||||
|
minimumFontSize = (int) value;
|
||||||
|
break;
|
||||||
|
case "verticalScrollBarEnabled":
|
||||||
|
verticalScrollBarEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "horizontalScrollBarEnabled":
|
||||||
|
horizontalScrollBarEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "resourceCustomSchemes":
|
||||||
|
resourceCustomSchemes = (List<String>) value;
|
||||||
|
break;
|
||||||
|
case "contentBlockers":
|
||||||
|
contentBlockers = (List<Map<String, Map<String, Object>>>) value;
|
||||||
|
break;
|
||||||
|
case "preferredContentMode":
|
||||||
|
preferredContentMode = (int) value;
|
||||||
|
break;
|
||||||
|
case "useShouldInterceptAjaxRequest":
|
||||||
|
useShouldInterceptAjaxRequest = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "useShouldInterceptFetchRequest":
|
||||||
|
useShouldInterceptFetchRequest = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "incognito":
|
||||||
|
incognito = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "cacheEnabled":
|
||||||
|
cacheEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "transparentBackground":
|
||||||
|
transparentBackground = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "disableVerticalScroll":
|
||||||
|
disableVerticalScroll = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "disableHorizontalScroll":
|
||||||
|
disableHorizontalScroll = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "textZoom":
|
||||||
|
textZoom = (int) value;
|
||||||
|
break;
|
||||||
|
case "clearSessionCache":
|
||||||
|
clearSessionCache = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "builtInZoomControls":
|
||||||
|
builtInZoomControls = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "displayZoomControls":
|
||||||
|
displayZoomControls = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "supportZoom":
|
||||||
|
supportZoom = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "databaseEnabled":
|
||||||
|
databaseEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "domStorageEnabled":
|
||||||
|
domStorageEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "useWideViewPort":
|
||||||
|
useWideViewPort = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "safeBrowsingEnabled":
|
||||||
|
safeBrowsingEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "mixedContentMode":
|
||||||
|
mixedContentMode = (int) value;
|
||||||
|
break;
|
||||||
|
case "allowContentAccess":
|
||||||
|
allowContentAccess = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "allowFileAccess":
|
||||||
|
allowFileAccess = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "allowFileAccessFromFileURLs":
|
||||||
|
allowFileAccessFromFileURLs = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "allowUniversalAccessFromFileURLs":
|
||||||
|
allowUniversalAccessFromFileURLs = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "appCachePath":
|
||||||
|
appCachePath = (String) value;
|
||||||
|
break;
|
||||||
|
case "blockNetworkImage":
|
||||||
|
blockNetworkImage = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "blockNetworkLoads":
|
||||||
|
blockNetworkLoads = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "cacheMode":
|
||||||
|
cacheMode = (int) value;
|
||||||
|
break;
|
||||||
|
case "cursiveFontFamily":
|
||||||
|
cursiveFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "defaultFixedFontSize":
|
||||||
|
defaultFixedFontSize = (int) value;
|
||||||
|
break;
|
||||||
|
case "defaultFontSize":
|
||||||
|
defaultFontSize = (int) value;
|
||||||
|
break;
|
||||||
|
case "defaultTextEncodingName":
|
||||||
|
defaultTextEncodingName = (String) value;
|
||||||
|
break;
|
||||||
|
case "disabledActionModeMenuItems":
|
||||||
|
disabledActionModeMenuItems = (int) value;
|
||||||
|
break;
|
||||||
|
case "fantasyFontFamily":
|
||||||
|
fantasyFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "fixedFontFamily":
|
||||||
|
fixedFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "forceDark":
|
||||||
|
forceDark = (int) value;
|
||||||
|
break;
|
||||||
|
case "geolocationEnabled":
|
||||||
|
geolocationEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "layoutAlgorithm":
|
||||||
|
setLayoutAlgorithm(pair);
|
||||||
|
break;
|
||||||
|
case "loadWithOverviewMode":
|
||||||
|
loadWithOverviewMode = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "loadsImagesAutomatically":
|
||||||
|
loadsImagesAutomatically = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "minimumLogicalFontSize":
|
||||||
|
minimumLogicalFontSize = (int) value;
|
||||||
|
break;
|
||||||
|
case "initialScale":
|
||||||
|
initialScale = (int) value;
|
||||||
|
break;
|
||||||
|
case "needInitialFocus":
|
||||||
|
needInitialFocus = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "offscreenPreRaster":
|
||||||
|
offscreenPreRaster = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "sansSerifFontFamily":
|
||||||
|
sansSerifFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "serifFontFamily":
|
||||||
|
serifFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "standardFontFamily":
|
||||||
|
standardFontFamily = (String) value;
|
||||||
|
break;
|
||||||
|
case "saveFormData":
|
||||||
|
saveFormData = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "thirdPartyCookiesEnabled":
|
||||||
|
thirdPartyCookiesEnabled = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "hardwareAcceleration":
|
||||||
|
hardwareAcceleration = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "supportMultipleWindows":
|
||||||
|
supportMultipleWindows = (boolean) value;
|
||||||
|
break;
|
||||||
|
case "regexToCancelSubFramesLoading":
|
||||||
|
regexToCancelSubFramesLoading = (String) value;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setLayoutAlgorithm(Map.Entry<String, Object> pair) {
|
||||||
if (pair.getKey().equals("layoutAlgorithm")) {
|
if (pair.getKey().equals("layoutAlgorithm")) {
|
||||||
String value = (String) pair.getValue();
|
String value = (String) pair.getValue();
|
||||||
if (value != null) {
|
if (value != null) {
|
||||||
switch (value) {
|
switch (value) {
|
||||||
case "NORMAL":
|
case "NORMAL":
|
||||||
pair.setValue(NORMAL);
|
this.layoutAlgorithm = NORMAL;
|
||||||
return pair;
|
|
||||||
case "TEXT_AUTOSIZING":
|
case "TEXT_AUTOSIZING":
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
|
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
|
||||||
return pair.setValue(WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING);
|
this.layoutAlgorithm = WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING;
|
||||||
} else {
|
} else {
|
||||||
pair.setValue(NORMAL);
|
layoutAlgorithm = NORMAL;
|
||||||
}
|
}
|
||||||
return pair;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return super.onParse(pair);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object onGetHashMap(Field field) {
|
public HashMap<String, Object> getHashMap() {
|
||||||
if (field.getName().equals("layoutAlgorithm")) {
|
HashMap<String, Object> options = new HashMap<>();
|
||||||
try {
|
options.put("useShouldOverrideUrlLoading", useShouldOverrideUrlLoading);
|
||||||
WebSettings.LayoutAlgorithm value = (WebSettings.LayoutAlgorithm) field.get(this);
|
options.put("useOnLoadResource", useOnLoadResource);
|
||||||
if (value != null) {
|
options.put("useOnDownloadStart", useOnDownloadStart);
|
||||||
switch (value) {
|
options.put("clearCache", clearCache);
|
||||||
case NORMAL:
|
options.put("userAgent", userAgent);
|
||||||
return "NORMAL";
|
options.put("applicationNameForUserAgent", applicationNameForUserAgent);
|
||||||
default:
|
options.put("javaScriptEnabled", javaScriptEnabled);
|
||||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && value.equals(WebSettings.LayoutAlgorithm.TEXT_AUTOSIZING)) {
|
options.put("debuggingEnabled", debuggingEnabled);
|
||||||
return "TEXT_AUTOSIZING";
|
options.put("javaScriptCanOpenWindowsAutomatically", javaScriptCanOpenWindowsAutomatically);
|
||||||
}
|
options.put("mediaPlaybackRequiresUserGesture", mediaPlaybackRequiresUserGesture);
|
||||||
return "NORMAL";
|
options.put("minimumFontSize", minimumFontSize);
|
||||||
}
|
options.put("verticalScrollBarEnabled", verticalScrollBarEnabled);
|
||||||
}
|
options.put("horizontalScrollBarEnabled", horizontalScrollBarEnabled);
|
||||||
} catch (IllegalAccessException e) {
|
options.put("resourceCustomSchemes", resourceCustomSchemes);
|
||||||
Log.d(LOG_TAG, e.getMessage());
|
options.put("contentBlockers", contentBlockers);
|
||||||
}
|
options.put("preferredContentMode", preferredContentMode);
|
||||||
}
|
options.put("useShouldInterceptAjaxRequest", useShouldInterceptAjaxRequest);
|
||||||
return super.onGetHashMap(field);
|
options.put("useShouldInterceptFetchRequest", useShouldInterceptFetchRequest);
|
||||||
|
options.put("incognito", incognito);
|
||||||
|
options.put("cacheEnabled", cacheEnabled);
|
||||||
|
options.put("transparentBackground", transparentBackground);
|
||||||
|
options.put("disableVerticalScroll", disableVerticalScroll);
|
||||||
|
options.put("disableHorizontalScroll", disableHorizontalScroll);
|
||||||
|
options.put("textZoom", textZoom);
|
||||||
|
options.put("clearSessionCache", clearSessionCache);
|
||||||
|
options.put("builtInZoomControls", builtInZoomControls);
|
||||||
|
options.put("displayZoomControls", displayZoomControls);
|
||||||
|
options.put("supportZoom", supportZoom);
|
||||||
|
options.put("databaseEnabled", databaseEnabled);
|
||||||
|
options.put("domStorageEnabled", domStorageEnabled);
|
||||||
|
options.put("useWideViewPort", useWideViewPort);
|
||||||
|
options.put("safeBrowsingEnabled", safeBrowsingEnabled);
|
||||||
|
options.put("mixedContentMode", mixedContentMode);
|
||||||
|
options.put("allowContentAccess", allowContentAccess);
|
||||||
|
options.put("allowFileAccess", allowFileAccess);
|
||||||
|
options.put("allowFileAccessFromFileURLs", allowFileAccessFromFileURLs);
|
||||||
|
options.put("allowUniversalAccessFromFileURLs", allowUniversalAccessFromFileURLs);
|
||||||
|
options.put("appCachePath", appCachePath);
|
||||||
|
options.put("blockNetworkImage", blockNetworkImage);
|
||||||
|
options.put("blockNetworkLoads", blockNetworkLoads);
|
||||||
|
options.put("cacheMode", cacheMode);
|
||||||
|
options.put("cursiveFontFamily", cursiveFontFamily);
|
||||||
|
options.put("defaultFixedFontSize", defaultFixedFontSize);
|
||||||
|
options.put("defaultFontSize", defaultFontSize);
|
||||||
|
options.put("defaultTextEncodingName", defaultTextEncodingName);
|
||||||
|
options.put("disabledActionModeMenuItems", disabledActionModeMenuItems);
|
||||||
|
options.put("fantasyFontFamily", fantasyFontFamily);
|
||||||
|
options.put("fixedFontFamily", fixedFontFamily);
|
||||||
|
options.put("forceDark", forceDark);
|
||||||
|
options.put("geolocationEnabled", geolocationEnabled);
|
||||||
|
options.put("layoutAlgorithm", layoutAlgorithm);
|
||||||
|
options.put("loadWithOverviewMode", loadWithOverviewMode);
|
||||||
|
options.put("loadsImagesAutomatically", loadsImagesAutomatically);
|
||||||
|
options.put("minimumLogicalFontSize", minimumLogicalFontSize);
|
||||||
|
options.put("initialScale", initialScale);
|
||||||
|
options.put("needInitialFocus", needInitialFocus);
|
||||||
|
options.put("offscreenPreRaster", offscreenPreRaster);
|
||||||
|
options.put("sansSerifFontFamily", sansSerifFontFamily);
|
||||||
|
options.put("serifFontFamily", serifFontFamily);
|
||||||
|
options.put("standardFontFamily", standardFontFamily);
|
||||||
|
options.put("saveFormData", saveFormData);
|
||||||
|
options.put("thirdPartyCookiesEnabled", thirdPartyCookiesEnabled);
|
||||||
|
options.put("hardwareAcceleration", hardwareAcceleration);
|
||||||
|
options.put("supportMultipleWindows", supportMultipleWindows);
|
||||||
|
options.put("regexToCancelSubFramesLoading", regexToCancelSubFramesLoading);
|
||||||
|
|
||||||
|
return options;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,51 +1,7 @@
|
||||||
package com.pichillilorenzo.flutter_inappwebview;
|
package com.pichillilorenzo.flutter_inappwebview;
|
||||||
|
|
||||||
import android.util.Log;
|
|
||||||
|
|
||||||
import java.lang.reflect.Field;
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
|
||||||
public class Options {
|
public interface Options {
|
||||||
|
HashMap<String, Object> getHashMap();
|
||||||
static String LOG_TAG = "Options";
|
|
||||||
|
|
||||||
public Options parse(HashMap<String, Object> options) {
|
|
||||||
Iterator it = options.entrySet().iterator();
|
|
||||||
while (it.hasNext()) {
|
|
||||||
Map.Entry<String, Object> pair = (Map.Entry<String, Object>) it.next();
|
|
||||||
Object value = this.onParse(pair);
|
|
||||||
try {
|
|
||||||
this.getClass().getDeclaredField(pair.getKey()).set(this, value);
|
|
||||||
} catch (NoSuchFieldException e) {
|
|
||||||
Log.d(LOG_TAG, e.getMessage());
|
|
||||||
} catch (IllegalAccessException e) {
|
|
||||||
Log.d(LOG_TAG, e.getMessage());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object onParse(Map.Entry<String, Object> pair) {
|
|
||||||
return pair.getValue();
|
|
||||||
}
|
|
||||||
|
|
||||||
public HashMap<String, Object> getHashMap() {
|
|
||||||
HashMap<String, Object> options = new HashMap<>();
|
|
||||||
for (Field field : this.getClass().getDeclaredFields()) {
|
|
||||||
options.put(field.getName(), onGetHashMap(field));
|
|
||||||
}
|
|
||||||
return options;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Object onGetHashMap(Field field) {
|
|
||||||
try {
|
|
||||||
return field.get(this);
|
|
||||||
} catch (IllegalAccessException e) {
|
|
||||||
Log.d(LOG_TAG, e.getMessage());
|
|
||||||
}
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue