You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
145 lines
4.6 KiB
Java
145 lines
4.6 KiB
Java
/*
|
|
Licensed to the Apache Software Foundation (ASF) under one
|
|
or more contributor license agreements. See the NOTICE file
|
|
distributed with this work for additional information
|
|
regarding copyright ownership. The ASF licenses this file
|
|
to you under the Apache License, Version 2.0 (the
|
|
"License"); you may not use this file except in compliance
|
|
with the License. You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing,
|
|
software distributed under the License is distributed on an
|
|
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
KIND, either express or implied. See the License for the
|
|
specific language governing permissions and limitations
|
|
under the License.
|
|
*/
|
|
package org.apache.cordova;
|
|
|
|
import org.json.JSONArray;
|
|
|
|
import android.util.Log;
|
|
|
|
import org.apache.cordova.CordovaWebView;
|
|
import org.apache.cordova.PluginResult;
|
|
import org.json.JSONObject;
|
|
|
|
public class CallbackContext {
|
|
private static final String LOG_TAG = "CordovaPlugin";
|
|
|
|
private String callbackId;
|
|
private CordovaWebView webView;
|
|
protected boolean finished;
|
|
private int changingThreads;
|
|
|
|
public CallbackContext(String callbackId, CordovaWebView webView) {
|
|
this.callbackId = callbackId;
|
|
this.webView = webView;
|
|
}
|
|
|
|
public boolean isFinished() {
|
|
return finished;
|
|
}
|
|
|
|
public boolean isChangingThreads() {
|
|
return changingThreads > 0;
|
|
}
|
|
|
|
public String getCallbackId() {
|
|
return callbackId;
|
|
}
|
|
|
|
public void sendPluginResult(PluginResult pluginResult) {
|
|
synchronized (this) {
|
|
if (finished) {
|
|
Log.w(LOG_TAG, "Attempted to send a second callback for ID: " + callbackId + "\nResult was: " + pluginResult.getMessage());
|
|
return;
|
|
} else {
|
|
finished = !pluginResult.getKeepCallback();
|
|
}
|
|
}
|
|
webView.sendPluginResult(pluginResult, callbackId);
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*
|
|
* @param message The message to add to the success result.
|
|
*/
|
|
public void success(JSONObject message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*
|
|
* @param message The message to add to the success result.
|
|
*/
|
|
public void success(String message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*
|
|
* @param message The message to add to the success result.
|
|
*/
|
|
public void success(JSONArray message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*
|
|
* @param message The message to add to the success result.
|
|
*/
|
|
public void success(byte[] message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*
|
|
* @param message The message to add to the success result.
|
|
*/
|
|
public void success(int message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for success callbacks that just returns the Status.OK by default
|
|
*/
|
|
public void success() {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.OK));
|
|
}
|
|
|
|
/**
|
|
* Helper for error callbacks that just returns the Status.ERROR by default
|
|
*
|
|
* @param message The message to add to the error result.
|
|
*/
|
|
public void error(JSONObject message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.ERROR, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for error callbacks that just returns the Status.ERROR by default
|
|
*
|
|
* @param message The message to add to the error result.
|
|
*/
|
|
public void error(String message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.ERROR, message));
|
|
}
|
|
|
|
/**
|
|
* Helper for error callbacks that just returns the Status.ERROR by default
|
|
*
|
|
* @param message The message to add to the error result.
|
|
*/
|
|
public void error(int message) {
|
|
sendPluginResult(new PluginResult(PluginResult.Status.ERROR, message));
|
|
}
|
|
}
|