mirror of
https://github.com/apache/cordova-android.git
synced 2025-04-07 07:13:07 +08:00
Putting back the CordovaInterface work after talking with Simon
This commit is contained in:
parent
d2fc08959a
commit
79935d31ef
@ -24,5 +24,5 @@ import android.app.Activity;
|
|||||||
* The Cordova activity abstract class that is extended by DroidGap.
|
* The Cordova activity abstract class that is extended by DroidGap.
|
||||||
* It is used to isolate plugin development, and remove dependency on entire Cordova library.
|
* It is used to isolate plugin development, and remove dependency on entire Cordova library.
|
||||||
*/
|
*/
|
||||||
public abstract class PhonegapActivity extends org.apache.cordova.api.CordovaInterface {
|
public abstract class PhonegapActivity extends Activity implements org.apache.cordova.api.CordovaInterface {
|
||||||
}
|
}
|
||||||
|
@ -175,9 +175,9 @@ public class CameraLauncher extends Plugin {
|
|||||||
private File createCaptureFile(int encodingType) {
|
private File createCaptureFile(int encodingType) {
|
||||||
File photo = null;
|
File photo = null;
|
||||||
if (encodingType == JPEG) {
|
if (encodingType == JPEG) {
|
||||||
photo = new File(DirectoryManager.getTempDirectoryPath(ctx), "Pic.jpg");
|
photo = new File(DirectoryManager.getTempDirectoryPath(ctx.getContext()), "Pic.jpg");
|
||||||
} else if (encodingType == PNG) {
|
} else if (encodingType == PNG) {
|
||||||
photo = new File(DirectoryManager.getTempDirectoryPath(ctx), "Pic.png");
|
photo = new File(DirectoryManager.getTempDirectoryPath(ctx.getContext()), "Pic.png");
|
||||||
} else {
|
} else {
|
||||||
throw new IllegalArgumentException("Invalid Encoding Type: " + encodingType);
|
throw new IllegalArgumentException("Invalid Encoding Type: " + encodingType);
|
||||||
}
|
}
|
||||||
@ -281,7 +281,7 @@ public class CameraLauncher extends Plugin {
|
|||||||
// Create an ExifHelper to save the exif data that is lost during compression
|
// Create an ExifHelper to save the exif data that is lost during compression
|
||||||
ExifHelper exif = new ExifHelper();
|
ExifHelper exif = new ExifHelper();
|
||||||
if (this.encodingType == JPEG) {
|
if (this.encodingType == JPEG) {
|
||||||
exif.createInFile(DirectoryManager.getTempDirectoryPath(ctx) + "/Pic.jpg");
|
exif.createInFile(DirectoryManager.getTempDirectoryPath(ctx.getContext()) + "/Pic.jpg");
|
||||||
exif.readExifData();
|
exif.readExifData();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -394,7 +394,7 @@ public class CameraLauncher extends Plugin {
|
|||||||
Bitmap bitmap = android.graphics.BitmapFactory.decodeStream(resolver.openInputStream(uri));
|
Bitmap bitmap = android.graphics.BitmapFactory.decodeStream(resolver.openInputStream(uri));
|
||||||
bitmap = scaleBitmap(bitmap);
|
bitmap = scaleBitmap(bitmap);
|
||||||
|
|
||||||
String fileName = DirectoryManager.getTempDirectoryPath(ctx) + "/resize.jpg";
|
String fileName = DirectoryManager.getTempDirectoryPath(ctx.getContext()) + "/resize.jpg";
|
||||||
OutputStream os = new FileOutputStream(fileName);
|
OutputStream os = new FileOutputStream(fileName);
|
||||||
bitmap.compress(Bitmap.CompressFormat.JPEG, this.mQuality, os);
|
bitmap.compress(Bitmap.CompressFormat.JPEG, this.mQuality, os);
|
||||||
os.close();
|
os.close();
|
||||||
@ -497,4 +497,4 @@ public class CameraLauncher extends Plugin {
|
|||||||
public void failPicture(String err) {
|
public void failPicture(String err) {
|
||||||
this.error(new PluginResult(PluginResult.Status.ERROR, err), this.callbackId);
|
this.error(new PluginResult(PluginResult.Status.ERROR, err), this.callbackId);
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -196,7 +196,7 @@ public class Capture extends Plugin {
|
|||||||
Intent intent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
|
Intent intent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE);
|
||||||
|
|
||||||
// Specify file so that large image is captured and returned
|
// Specify file so that large image is captured and returned
|
||||||
File photo = new File(DirectoryManager.getTempDirectoryPath(ctx), "Capture.jpg");
|
File photo = new File(DirectoryManager.getTempDirectoryPath(ctx.getContext()), "Capture.jpg");
|
||||||
intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, Uri.fromFile(photo));
|
intent.putExtra(android.provider.MediaStore.EXTRA_OUTPUT, Uri.fromFile(photo));
|
||||||
this.imageUri = Uri.fromFile(photo);
|
this.imageUri = Uri.fromFile(photo);
|
||||||
|
|
||||||
@ -249,7 +249,7 @@ public class Capture extends Plugin {
|
|||||||
try {
|
try {
|
||||||
// Create an ExifHelper to save the exif data that is lost during compression
|
// Create an ExifHelper to save the exif data that is lost during compression
|
||||||
ExifHelper exif = new ExifHelper();
|
ExifHelper exif = new ExifHelper();
|
||||||
exif.createInFile(DirectoryManager.getTempDirectoryPath(ctx) + "/Capture.jpg");
|
exif.createInFile(DirectoryManager.getTempDirectoryPath(ctx.getContext()) + "/Capture.jpg");
|
||||||
exif.readExifData();
|
exif.readExifData();
|
||||||
|
|
||||||
// Read in bitmap of captured image
|
// Read in bitmap of captured image
|
||||||
|
@ -26,34 +26,34 @@ import org.json.JSONObject;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
public class ContactManager extends Plugin {
|
public class ContactManager extends Plugin {
|
||||||
|
|
||||||
private ContactAccessor contactAccessor;
|
private ContactAccessor contactAccessor;
|
||||||
private static final String LOG_TAG = "Contact Query";
|
private static final String LOG_TAG = "Contact Query";
|
||||||
|
|
||||||
public static final int UNKNOWN_ERROR = 0;
|
public static final int UNKNOWN_ERROR = 0;
|
||||||
public static final int INVALID_ARGUMENT_ERROR = 1;
|
public static final int INVALID_ARGUMENT_ERROR = 1;
|
||||||
public static final int TIMEOUT_ERROR = 2;
|
public static final int TIMEOUT_ERROR = 2;
|
||||||
public static final int PENDING_OPERATION_ERROR = 3;
|
public static final int PENDING_OPERATION_ERROR = 3;
|
||||||
public static final int IO_ERROR = 4;
|
public static final int IO_ERROR = 4;
|
||||||
public static final int NOT_SUPPORTED_ERROR = 5;
|
public static final int NOT_SUPPORTED_ERROR = 5;
|
||||||
public static final int PERMISSION_DENIED_ERROR = 20;
|
public static final int PERMISSION_DENIED_ERROR = 20;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*/
|
*/
|
||||||
public ContactManager() {
|
public ContactManager() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes the request and returns PluginResult.
|
* Executes the request and returns PluginResult.
|
||||||
*
|
*
|
||||||
* @param action The action to execute.
|
* @param action The action to execute.
|
||||||
* @param args JSONArry of arguments for the plugin.
|
* @param args JSONArry of arguments for the plugin.
|
||||||
* @param callbackId The callback id used when calling back into JavaScript.
|
* @param callbackId The callback id used when calling back into JavaScript.
|
||||||
* @return A PluginResult object with a status and message.
|
* @return A PluginResult object with a status and message.
|
||||||
*/
|
*/
|
||||||
public PluginResult execute(String action, JSONArray args, String callbackId) {
|
public PluginResult execute(String action, JSONArray args, String callbackId) {
|
||||||
PluginResult.Status status = PluginResult.Status.OK;
|
PluginResult.Status status = PluginResult.Status.OK;
|
||||||
String result = "";
|
String result = "";
|
||||||
|
|
||||||
@ -79,35 +79,35 @@ public class ContactManager extends Plugin {
|
|||||||
* older phones.
|
* older phones.
|
||||||
*/
|
*/
|
||||||
if (this.contactAccessor == null) {
|
if (this.contactAccessor == null) {
|
||||||
this.contactAccessor = new ContactAccessorSdk5(this.webView, this.ctx);
|
this.contactAccessor = new ContactAccessorSdk5(this.webView, this.ctx.getContext());
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (action.equals("search")) {
|
if (action.equals("search")) {
|
||||||
JSONArray res = contactAccessor.search(args.getJSONArray(0), args.optJSONObject(1));
|
JSONArray res = contactAccessor.search(args.getJSONArray(0), args.optJSONObject(1));
|
||||||
return new PluginResult(status, res);
|
return new PluginResult(status, res);
|
||||||
}
|
}
|
||||||
else if (action.equals("save")) {
|
else if (action.equals("save")) {
|
||||||
String id = contactAccessor.save(args.getJSONObject(0));
|
String id = contactAccessor.save(args.getJSONObject(0));
|
||||||
if (id != null) {
|
if (id != null) {
|
||||||
JSONObject res = contactAccessor.getContactById(id);
|
JSONObject res = contactAccessor.getContactById(id);
|
||||||
if (res != null) {
|
if (res != null) {
|
||||||
return new PluginResult(status, res);
|
return new PluginResult(status, res);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (action.equals("remove")) {
|
else if (action.equals("remove")) {
|
||||||
if (contactAccessor.remove(args.getString(0))) {
|
if (contactAccessor.remove(args.getString(0))) {
|
||||||
return new PluginResult(status, result);
|
return new PluginResult(status, result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// If we get to this point an error has occurred
|
// If we get to this point an error has occurred
|
||||||
JSONObject r = new JSONObject();
|
JSONObject r = new JSONObject();
|
||||||
r.put("code", UNKNOWN_ERROR);
|
r.put("code", UNKNOWN_ERROR);
|
||||||
return new PluginResult(PluginResult.Status.ERROR, r);
|
return new PluginResult(PluginResult.Status.ERROR, r);
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
Log.e(LOG_TAG, e.getMessage(), e);
|
Log.e(LOG_TAG, e.getMessage(), e);
|
||||||
return new PluginResult(PluginResult.Status.JSON_EXCEPTION);
|
return new PluginResult(PluginResult.Status.JSON_EXCEPTION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -145,7 +145,7 @@ import android.widget.LinearLayout;
|
|||||||
* ...
|
* ...
|
||||||
* </plugins>
|
* </plugins>
|
||||||
*/
|
*/
|
||||||
public class DroidGap extends CordovaInterface {
|
public class DroidGap extends Activity implements CordovaInterface {
|
||||||
public static String TAG = "DroidGap";
|
public static String TAG = "DroidGap";
|
||||||
|
|
||||||
// The webview for our app
|
// The webview for our app
|
||||||
@ -1404,4 +1404,14 @@ public class DroidGap extends CordovaInterface {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void bindBackButton(boolean override) {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
this.bound = override;
|
||||||
|
}
|
||||||
|
|
||||||
|
public boolean isBackButtonBound() {
|
||||||
|
// TODO Auto-generated method stub
|
||||||
|
return this.bound;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -36,331 +36,331 @@ import android.os.Vibrator;
|
|||||||
* This class provides access to notifications on the device.
|
* This class provides access to notifications on the device.
|
||||||
*/
|
*/
|
||||||
public class Notification extends Plugin {
|
public class Notification extends Plugin {
|
||||||
|
|
||||||
public int confirmResult = -1;
|
public int confirmResult = -1;
|
||||||
public ProgressDialog spinnerDialog = null;
|
public ProgressDialog spinnerDialog = null;
|
||||||
public ProgressDialog progressDialog = null;
|
public ProgressDialog progressDialog = null;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*/
|
*/
|
||||||
public Notification() {
|
public Notification() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Executes the request and returns PluginResult.
|
* Executes the request and returns PluginResult.
|
||||||
*
|
*
|
||||||
* @param action The action to execute.
|
* @param action The action to execute.
|
||||||
* @param args JSONArry of arguments for the plugin.
|
* @param args JSONArry of arguments for the plugin.
|
||||||
* @param callbackId The callback id used when calling back into JavaScript.
|
* @param callbackId The callback id used when calling back into JavaScript.
|
||||||
* @return A PluginResult object with a status and message.
|
* @return A PluginResult object with a status and message.
|
||||||
*/
|
*/
|
||||||
public PluginResult execute(String action, JSONArray args, String callbackId) {
|
public PluginResult execute(String action, JSONArray args, String callbackId) {
|
||||||
PluginResult.Status status = PluginResult.Status.OK;
|
PluginResult.Status status = PluginResult.Status.OK;
|
||||||
String result = "";
|
String result = "";
|
||||||
|
|
||||||
try {
|
try {
|
||||||
if (action.equals("beep")) {
|
if (action.equals("beep")) {
|
||||||
this.beep(args.getLong(0));
|
this.beep(args.getLong(0));
|
||||||
}
|
}
|
||||||
else if (action.equals("vibrate")) {
|
else if (action.equals("vibrate")) {
|
||||||
this.vibrate(args.getLong(0));
|
this.vibrate(args.getLong(0));
|
||||||
}
|
}
|
||||||
else if (action.equals("alert")) {
|
else if (action.equals("alert")) {
|
||||||
this.alert(args.getString(0),args.getString(1),args.getString(2), callbackId);
|
this.alert(args.getString(0),args.getString(1),args.getString(2), callbackId);
|
||||||
PluginResult r = new PluginResult(PluginResult.Status.NO_RESULT);
|
PluginResult r = new PluginResult(PluginResult.Status.NO_RESULT);
|
||||||
r.setKeepCallback(true);
|
r.setKeepCallback(true);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
else if (action.equals("confirm")) {
|
else if (action.equals("confirm")) {
|
||||||
this.confirm(args.getString(0),args.getString(1),args.getString(2), callbackId);
|
this.confirm(args.getString(0),args.getString(1),args.getString(2), callbackId);
|
||||||
PluginResult r = new PluginResult(PluginResult.Status.NO_RESULT);
|
PluginResult r = new PluginResult(PluginResult.Status.NO_RESULT);
|
||||||
r.setKeepCallback(true);
|
r.setKeepCallback(true);
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
else if (action.equals("activityStart")) {
|
else if (action.equals("activityStart")) {
|
||||||
this.activityStart(args.getString(0),args.getString(1));
|
this.activityStart(args.getString(0),args.getString(1));
|
||||||
}
|
}
|
||||||
else if (action.equals("activityStop")) {
|
else if (action.equals("activityStop")) {
|
||||||
this.activityStop();
|
this.activityStop();
|
||||||
}
|
}
|
||||||
else if (action.equals("progressStart")) {
|
else if (action.equals("progressStart")) {
|
||||||
this.progressStart(args.getString(0),args.getString(1));
|
this.progressStart(args.getString(0),args.getString(1));
|
||||||
}
|
}
|
||||||
else if (action.equals("progressValue")) {
|
else if (action.equals("progressValue")) {
|
||||||
this.progressValue(args.getInt(0));
|
this.progressValue(args.getInt(0));
|
||||||
}
|
}
|
||||||
else if (action.equals("progressStop")) {
|
else if (action.equals("progressStop")) {
|
||||||
this.progressStop();
|
this.progressStop();
|
||||||
}
|
}
|
||||||
return new PluginResult(status, result);
|
return new PluginResult(status, result);
|
||||||
} catch (JSONException e) {
|
} catch (JSONException e) {
|
||||||
return new PluginResult(PluginResult.Status.JSON_EXCEPTION);
|
return new PluginResult(PluginResult.Status.JSON_EXCEPTION);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Identifies if action to be executed returns a value and should be run synchronously.
|
* Identifies if action to be executed returns a value and should be run synchronously.
|
||||||
*
|
*
|
||||||
* @param action The action to execute
|
* @param action The action to execute
|
||||||
* @return T=returns value
|
* @return T=returns value
|
||||||
*/
|
*/
|
||||||
public boolean isSynch(String action) {
|
public boolean isSynch(String action) {
|
||||||
if (action.equals("alert")) {
|
if (action.equals("alert")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("confirm")) {
|
else if (action.equals("confirm")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("activityStart")) {
|
else if (action.equals("activityStart")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("activityStop")) {
|
else if (action.equals("activityStop")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("progressStart")) {
|
else if (action.equals("progressStart")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("progressValue")) {
|
else if (action.equals("progressValue")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (action.equals("progressStop")) {
|
else if (action.equals("progressStop")) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
// LOCAL METHODS
|
// LOCAL METHODS
|
||||||
//--------------------------------------------------------------------------
|
//--------------------------------------------------------------------------
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Beep plays the default notification ringtone.
|
* Beep plays the default notification ringtone.
|
||||||
*
|
*
|
||||||
* @param count Number of times to play notification
|
* @param count Number of times to play notification
|
||||||
*/
|
*/
|
||||||
public void beep(long count) {
|
public void beep(long count) {
|
||||||
Uri ringtone = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
|
Uri ringtone = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
|
||||||
Ringtone notification = RingtoneManager.getRingtone(this.ctx, ringtone);
|
Ringtone notification = RingtoneManager.getRingtone(this.ctx.getContext(), ringtone);
|
||||||
|
|
||||||
// If phone is not set to silent mode
|
// If phone is not set to silent mode
|
||||||
if (notification != null) {
|
if (notification != null) {
|
||||||
for (long i = 0; i < count; ++i) {
|
for (long i = 0; i < count; ++i) {
|
||||||
notification.play();
|
notification.play();
|
||||||
long timeout = 5000;
|
long timeout = 5000;
|
||||||
while (notification.isPlaying() && (timeout > 0)) {
|
while (notification.isPlaying() && (timeout > 0)) {
|
||||||
timeout = timeout - 100;
|
timeout = timeout - 100;
|
||||||
try {
|
try {
|
||||||
Thread.sleep(100);
|
Thread.sleep(100);
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Vibrates the device for the specified amount of time.
|
* Vibrates the device for the specified amount of time.
|
||||||
*
|
*
|
||||||
* @param time Time to vibrate in ms.
|
* @param time Time to vibrate in ms.
|
||||||
*/
|
*/
|
||||||
public void vibrate(long time){
|
public void vibrate(long time){
|
||||||
// Start the vibration, 0 defaults to half a second.
|
// Start the vibration, 0 defaults to half a second.
|
||||||
if (time == 0) {
|
if (time == 0) {
|
||||||
time = 500;
|
time = 500;
|
||||||
}
|
}
|
||||||
Vibrator vibrator = (Vibrator) this.ctx.getSystemService(Context.VIBRATOR_SERVICE);
|
Vibrator vibrator = (Vibrator) this.ctx.getSystemService(Context.VIBRATOR_SERVICE);
|
||||||
vibrator.vibrate(time);
|
vibrator.vibrate(time);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds and shows a native Android alert with given Strings
|
* Builds and shows a native Android alert with given Strings
|
||||||
* @param message The message the alert should display
|
* @param message The message the alert should display
|
||||||
* @param title The title of the alert
|
* @param title The title of the alert
|
||||||
* @param buttonLabel The label of the button
|
* @param buttonLabel The label of the button
|
||||||
* @param callbackId The callback id
|
* @param callbackId The callback id
|
||||||
*/
|
*/
|
||||||
public synchronized void alert(final String message, final String title, final String buttonLabel, final String callbackId) {
|
public synchronized void alert(final String message, final String title, final String buttonLabel, final String callbackId) {
|
||||||
|
|
||||||
final CordovaInterface ctx = this.ctx;
|
final CordovaInterface ctx = this.ctx;
|
||||||
final Notification notification = this;
|
final Notification notification = this;
|
||||||
|
|
||||||
Runnable runnable = new Runnable() {
|
Runnable runnable = new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
|
|
||||||
AlertDialog.Builder dlg = new AlertDialog.Builder(ctx);
|
AlertDialog.Builder dlg = new AlertDialog.Builder(ctx.getContext());
|
||||||
dlg.setMessage(message);
|
dlg.setMessage(message);
|
||||||
dlg.setTitle(title);
|
dlg.setTitle(title);
|
||||||
dlg.setCancelable(false);
|
dlg.setCancelable(false);
|
||||||
dlg.setPositiveButton(buttonLabel,
|
dlg.setPositiveButton(buttonLabel,
|
||||||
new AlertDialog.OnClickListener() {
|
new AlertDialog.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
notification.success(new PluginResult(PluginResult.Status.OK, 0), callbackId);
|
notification.success(new PluginResult(PluginResult.Status.OK, 0), callbackId);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
dlg.create();
|
dlg.create();
|
||||||
dlg.show();
|
dlg.show();
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
this.ctx.runOnUiThread(runnable);
|
this.ctx.runOnUiThread(runnable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Builds and shows a native Android confirm dialog with given title, message, buttons.
|
* Builds and shows a native Android confirm dialog with given title, message, buttons.
|
||||||
* This dialog only shows up to 3 buttons. Any labels after that will be ignored.
|
* This dialog only shows up to 3 buttons. Any labels after that will be ignored.
|
||||||
* The index of the button pressed will be returned to the JavaScript callback identified by callbackId.
|
* The index of the button pressed will be returned to the JavaScript callback identified by callbackId.
|
||||||
*
|
*
|
||||||
* @param message The message the dialog should display
|
* @param message The message the dialog should display
|
||||||
* @param title The title of the dialog
|
* @param title The title of the dialog
|
||||||
* @param buttonLabels A comma separated list of button labels (Up to 3 buttons)
|
* @param buttonLabels A comma separated list of button labels (Up to 3 buttons)
|
||||||
* @param callbackId The callback id
|
* @param callbackId The callback id
|
||||||
*/
|
*/
|
||||||
public synchronized void confirm(final String message, final String title, String buttonLabels, final String callbackId) {
|
public synchronized void confirm(final String message, final String title, String buttonLabels, final String callbackId) {
|
||||||
|
|
||||||
final CordovaInterface ctx = this.ctx;
|
final CordovaInterface ctx = this.ctx;
|
||||||
final Notification notification = this;
|
final Notification notification = this;
|
||||||
final String[] fButtons = buttonLabels.split(",");
|
final String[] fButtons = buttonLabels.split(",");
|
||||||
|
|
||||||
Runnable runnable = new Runnable() {
|
Runnable runnable = new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
AlertDialog.Builder dlg = new AlertDialog.Builder(ctx);
|
AlertDialog.Builder dlg = new AlertDialog.Builder(ctx.getContext());
|
||||||
dlg.setMessage(message);
|
dlg.setMessage(message);
|
||||||
dlg.setTitle(title);
|
dlg.setTitle(title);
|
||||||
dlg.setCancelable(false);
|
dlg.setCancelable(false);
|
||||||
|
|
||||||
// First button
|
// First button
|
||||||
if (fButtons.length > 0) {
|
if (fButtons.length > 0) {
|
||||||
dlg.setPositiveButton(fButtons[0],
|
dlg.setPositiveButton(fButtons[0],
|
||||||
new AlertDialog.OnClickListener() {
|
new AlertDialog.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
notification.success(new PluginResult(PluginResult.Status.OK, 1), callbackId);
|
notification.success(new PluginResult(PluginResult.Status.OK, 1), callbackId);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Second button
|
// Second button
|
||||||
if (fButtons.length > 1) {
|
if (fButtons.length > 1) {
|
||||||
dlg.setNeutralButton(fButtons[1],
|
dlg.setNeutralButton(fButtons[1],
|
||||||
new AlertDialog.OnClickListener() {
|
new AlertDialog.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
notification.success(new PluginResult(PluginResult.Status.OK, 2), callbackId);
|
notification.success(new PluginResult(PluginResult.Status.OK, 2), callbackId);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Third button
|
// Third button
|
||||||
if (fButtons.length > 2) {
|
if (fButtons.length > 2) {
|
||||||
dlg.setNegativeButton(fButtons[2],
|
dlg.setNegativeButton(fButtons[2],
|
||||||
new AlertDialog.OnClickListener() {
|
new AlertDialog.OnClickListener() {
|
||||||
public void onClick(DialogInterface dialog, int which) {
|
public void onClick(DialogInterface dialog, int which) {
|
||||||
dialog.dismiss();
|
dialog.dismiss();
|
||||||
notification.success(new PluginResult(PluginResult.Status.OK, 3), callbackId);
|
notification.success(new PluginResult(PluginResult.Status.OK, 3), callbackId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
dlg.create();
|
dlg.create();
|
||||||
dlg.show();
|
dlg.show();
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
this.ctx.runOnUiThread(runnable);
|
this.ctx.runOnUiThread(runnable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the spinner.
|
* Show the spinner.
|
||||||
*
|
*
|
||||||
* @param title Title of the dialog
|
* @param title Title of the dialog
|
||||||
* @param message The message of the dialog
|
* @param message The message of the dialog
|
||||||
*/
|
*/
|
||||||
public synchronized void activityStart(final String title, final String message) {
|
public synchronized void activityStart(final String title, final String message) {
|
||||||
if (this.spinnerDialog != null) {
|
if (this.spinnerDialog != null) {
|
||||||
this.spinnerDialog.dismiss();
|
this.spinnerDialog.dismiss();
|
||||||
this.spinnerDialog = null;
|
this.spinnerDialog = null;
|
||||||
}
|
}
|
||||||
final Notification notification = this;
|
final Notification notification = this;
|
||||||
final CordovaInterface ctx = this.ctx;
|
final CordovaInterface ctx = this.ctx;
|
||||||
Runnable runnable = new Runnable() {
|
Runnable runnable = new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
notification.spinnerDialog = ProgressDialog.show(ctx, title , message, true, true,
|
notification.spinnerDialog = ProgressDialog.show(ctx.getContext(), title , message, true, true,
|
||||||
new DialogInterface.OnCancelListener() {
|
new DialogInterface.OnCancelListener() {
|
||||||
public void onCancel(DialogInterface dialog) {
|
public void onCancel(DialogInterface dialog) {
|
||||||
notification.spinnerDialog = null;
|
notification.spinnerDialog = null;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
this.ctx.runOnUiThread(runnable);
|
this.ctx.runOnUiThread(runnable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stop spinner.
|
* Stop spinner.
|
||||||
*/
|
*/
|
||||||
public synchronized void activityStop() {
|
public synchronized void activityStop() {
|
||||||
if (this.spinnerDialog != null) {
|
if (this.spinnerDialog != null) {
|
||||||
this.spinnerDialog.dismiss();
|
this.spinnerDialog.dismiss();
|
||||||
this.spinnerDialog = null;
|
this.spinnerDialog = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Show the progress dialog.
|
* Show the progress dialog.
|
||||||
*
|
*
|
||||||
* @param title Title of the dialog
|
* @param title Title of the dialog
|
||||||
* @param message The message of the dialog
|
* @param message The message of the dialog
|
||||||
*/
|
*/
|
||||||
public synchronized void progressStart(final String title, final String message) {
|
public synchronized void progressStart(final String title, final String message) {
|
||||||
if (this.progressDialog != null) {
|
if (this.progressDialog != null) {
|
||||||
this.progressDialog.dismiss();
|
this.progressDialog.dismiss();
|
||||||
this.progressDialog = null;
|
this.progressDialog = null;
|
||||||
}
|
}
|
||||||
final Notification notification = this;
|
final Notification notification = this;
|
||||||
final CordovaInterface ctx = this.ctx;
|
final CordovaInterface ctx = this.ctx;
|
||||||
Runnable runnable = new Runnable() {
|
Runnable runnable = new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
notification.progressDialog = new ProgressDialog(ctx);
|
notification.progressDialog = new ProgressDialog(ctx.getContext());
|
||||||
notification.progressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
|
notification.progressDialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
|
||||||
notification.progressDialog.setTitle(title);
|
notification.progressDialog.setTitle(title);
|
||||||
notification.progressDialog.setMessage(message);
|
notification.progressDialog.setMessage(message);
|
||||||
notification.progressDialog.setCancelable(true);
|
notification.progressDialog.setCancelable(true);
|
||||||
notification.progressDialog.setMax(100);
|
notification.progressDialog.setMax(100);
|
||||||
notification.progressDialog.setProgress(0);
|
notification.progressDialog.setProgress(0);
|
||||||
notification.progressDialog.setOnCancelListener(
|
notification.progressDialog.setOnCancelListener(
|
||||||
new DialogInterface.OnCancelListener() {
|
new DialogInterface.OnCancelListener() {
|
||||||
public void onCancel(DialogInterface dialog) {
|
public void onCancel(DialogInterface dialog) {
|
||||||
notification.progressDialog = null;
|
notification.progressDialog = null;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
notification.progressDialog.show();
|
notification.progressDialog.show();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
this.ctx.runOnUiThread(runnable);
|
this.ctx.runOnUiThread(runnable);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set value of progress bar.
|
* Set value of progress bar.
|
||||||
*
|
*
|
||||||
* @param value 0-100
|
* @param value 0-100
|
||||||
*/
|
*/
|
||||||
public synchronized void progressValue(int value) {
|
public synchronized void progressValue(int value) {
|
||||||
if (this.progressDialog != null) {
|
if (this.progressDialog != null) {
|
||||||
this.progressDialog.setProgress(value);
|
this.progressDialog.setProgress(value);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stop progress dialog.
|
* Stop progress dialog.
|
||||||
*/
|
*/
|
||||||
public synchronized void progressStop() {
|
public synchronized void progressStop() {
|
||||||
if (this.progressDialog != null) {
|
if (this.progressDialog != null) {
|
||||||
this.progressDialog.dismiss();
|
this.progressDialog.dismiss();
|
||||||
this.progressDialog = null;
|
this.progressDialog = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -38,7 +38,7 @@ import android.net.Uri;
|
|||||||
* The Cordova activity abstract class that is extended by DroidGap.
|
* The Cordova activity abstract class that is extended by DroidGap.
|
||||||
* It is used to isolate plugin development, and remove dependency on entire Cordova library.
|
* It is used to isolate plugin development, and remove dependency on entire Cordova library.
|
||||||
*/
|
*/
|
||||||
public abstract class CordovaInterface extends Activity{
|
public interface CordovaInterface {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated
|
* @deprecated
|
||||||
@ -69,6 +69,13 @@ public abstract class CordovaInterface extends Activity{
|
|||||||
*/
|
*/
|
||||||
abstract public void startActivityForResult(IPlugin command, Intent intent, int requestCode);
|
abstract public void startActivityForResult(IPlugin command, Intent intent, int requestCode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Launch an activity for which you would not like a result when it finished.
|
||||||
|
*
|
||||||
|
* @param intent The intent to start
|
||||||
|
*/
|
||||||
|
abstract public void startActivity(Intent intent);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set the plugin to be called when a sub-activity exits.
|
* Set the plugin to be called when a sub-activity exits.
|
||||||
*
|
*
|
||||||
@ -90,5 +97,49 @@ public abstract class CordovaInterface extends Activity{
|
|||||||
* @param data The message data
|
* @param data The message data
|
||||||
*/
|
*/
|
||||||
abstract public void postMessage(String id, Object data);
|
abstract public void postMessage(String id, Object data);
|
||||||
|
|
||||||
|
|
||||||
|
public abstract Resources getResources();
|
||||||
|
|
||||||
|
public abstract String getPackageName();
|
||||||
|
|
||||||
|
public abstract Object getSystemService(String service);
|
||||||
|
|
||||||
|
public abstract Context getContext();
|
||||||
|
|
||||||
|
public abstract Context getBaseContext();
|
||||||
|
|
||||||
|
public abstract Intent registerReceiver(BroadcastReceiver receiver,
|
||||||
|
IntentFilter intentFilter);
|
||||||
|
|
||||||
|
public abstract ContentResolver getContentResolver();
|
||||||
|
|
||||||
|
public abstract void unregisterReceiver(BroadcastReceiver receiver);
|
||||||
|
|
||||||
|
public abstract Cursor managedQuery(Uri uri, String[] projection, String selection,
|
||||||
|
String[] selectionArgs, String sortOrder);
|
||||||
|
|
||||||
|
public abstract void runOnUiThread(Runnable runnable);
|
||||||
|
|
||||||
|
public abstract AssetManager getAssets();
|
||||||
|
|
||||||
|
public abstract void clearCache();
|
||||||
|
|
||||||
|
public abstract void clearHistory();
|
||||||
|
|
||||||
|
public abstract boolean backHistory();
|
||||||
|
|
||||||
|
//public abstract void addWhiteListEntry(String origin, boolean subdomains);
|
||||||
|
|
||||||
|
public abstract void bindBackButton(boolean override);
|
||||||
|
|
||||||
|
public abstract boolean isBackButtonBound();
|
||||||
|
|
||||||
|
public abstract void cancelLoadUrl();
|
||||||
|
|
||||||
|
public abstract void showWebPage(String url, boolean openExternal,
|
||||||
|
boolean clearHistory, HashMap<String, Object> params);
|
||||||
|
|
||||||
|
public abstract Context getApplicationContext();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user