mirror of
https://github.com/apache/cordova-android.git
synced 2025-02-07 23:03:11 +08:00
CB-2459: Customize InAppBrowser location bar
This commit is contained in:
parent
ce1a961b99
commit
e0d0d6c455
@ -72,6 +72,7 @@ public class InAppBrowser extends CordovaPlugin {
|
|||||||
private static final String EXIT_EVENT = "exit";
|
private static final String EXIT_EVENT = "exit";
|
||||||
private static final String LOAD_START_EVENT = "loadstart";
|
private static final String LOAD_START_EVENT = "loadstart";
|
||||||
private static final String LOAD_STOP_EVENT = "loadstop";
|
private static final String LOAD_STOP_EVENT = "loadstop";
|
||||||
|
private static final String CLOSE_BUTTON_CAPTION = "closebuttoncaption";
|
||||||
private long MAX_QUOTA = 100 * 1024 * 1024;
|
private long MAX_QUOTA = 100 * 1024 * 1024;
|
||||||
|
|
||||||
private Dialog dialog;
|
private Dialog dialog;
|
||||||
@ -79,6 +80,7 @@ public class InAppBrowser extends CordovaPlugin {
|
|||||||
private EditText edittext;
|
private EditText edittext;
|
||||||
private boolean showLocationBar = true;
|
private boolean showLocationBar = true;
|
||||||
private CallbackContext callbackContext;
|
private CallbackContext callbackContext;
|
||||||
|
private String buttonLabel = "Done";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes the request and returns PluginResult.
|
* Executes the request and returns PluginResult.
|
||||||
@ -177,10 +179,14 @@ public class InAppBrowser extends CordovaPlugin {
|
|||||||
option = new StringTokenizer(features.nextToken(), "=");
|
option = new StringTokenizer(features.nextToken(), "=");
|
||||||
if (option.hasMoreElements()) {
|
if (option.hasMoreElements()) {
|
||||||
String key = option.nextToken();
|
String key = option.nextToken();
|
||||||
|
if (key.equalsIgnoreCase(CLOSE_BUTTON_CAPTION)) {
|
||||||
|
this.buttonLabel = option.nextToken();
|
||||||
|
} else {
|
||||||
Boolean value = option.nextToken().equals("no") ? Boolean.FALSE : Boolean.TRUE;
|
Boolean value = option.nextToken().equals("no") ? Boolean.FALSE : Boolean.TRUE;
|
||||||
map.put(key, value);
|
map.put(key, value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return map;
|
return map;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -292,7 +298,10 @@ public class InAppBrowser extends CordovaPlugin {
|
|||||||
// Determine if we should hide the location bar.
|
// Determine if we should hide the location bar.
|
||||||
showLocationBar = true;
|
showLocationBar = true;
|
||||||
if (features != null) {
|
if (features != null) {
|
||||||
showLocationBar = features.get(LOCATION).booleanValue();
|
Boolean show = features.get(LOCATION);
|
||||||
|
if (show != null) {
|
||||||
|
showLocationBar = show.booleanValue();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final CordovaWebView thatWebView = this.webView;
|
final CordovaWebView thatWebView = this.webView;
|
||||||
@ -408,7 +417,7 @@ public class InAppBrowser extends CordovaPlugin {
|
|||||||
close.setLayoutParams(closeLayoutParams);
|
close.setLayoutParams(closeLayoutParams);
|
||||||
forward.setContentDescription("Close Button");
|
forward.setContentDescription("Close Button");
|
||||||
close.setId(5);
|
close.setId(5);
|
||||||
close.setText("Done");
|
close.setText(buttonLabel);
|
||||||
close.setOnClickListener(new View.OnClickListener() {
|
close.setOnClickListener(new View.OnClickListener() {
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
closeDialog();
|
closeDialog();
|
||||||
|
Loading…
Reference in New Issue
Block a user