2014-10-26 15:47:18 +00:00
|
|
|
/*
|
|
|
|
Copyright 2013-2014 appPlant UG
|
|
|
|
|
|
|
|
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.
|
2014-11-04 16:59:33 +00:00
|
|
|
*/
|
2014-10-26 15:47:18 +00:00
|
|
|
|
|
|
|
package de.appplant.cordova.plugin.background;
|
|
|
|
|
2014-11-04 16:59:33 +00:00
|
|
|
import org.apache.cordova.CallbackContext;
|
|
|
|
import org.apache.cordova.CordovaPlugin;
|
|
|
|
import org.json.JSONArray;
|
|
|
|
import org.json.JSONException;
|
|
|
|
import org.json.JSONObject;
|
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
import android.app.Activity;
|
|
|
|
import android.content.ComponentName;
|
|
|
|
import android.content.Context;
|
|
|
|
import android.content.Intent;
|
|
|
|
import android.content.ServiceConnection;
|
|
|
|
import android.os.IBinder;
|
|
|
|
import android.util.Log;
|
|
|
|
|
|
|
|
public class BackgroundMode extends CordovaPlugin {
|
|
|
|
|
2014-12-13 23:04:12 +00:00
|
|
|
// Event types for callbacks
|
|
|
|
private enum Event {
|
|
|
|
ACTIVATE, DEACTIVATE, FAILURE
|
|
|
|
}
|
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
// Flag indicates if the app is in background or foreground
|
|
|
|
private boolean inBackground = false;
|
|
|
|
|
|
|
|
// Flag indicates if the plugin is enabled or disabled
|
2014-11-12 22:04:01 +00:00
|
|
|
private boolean isDisabled = true;
|
2014-10-26 15:47:18 +00:00
|
|
|
|
2014-11-07 18:55:24 +00:00
|
|
|
// Flag indicates if the service is bind
|
|
|
|
private boolean isBind = false;
|
|
|
|
|
2014-11-04 14:48:14 +00:00
|
|
|
// Settings for the notification
|
2014-11-12 21:28:25 +00:00
|
|
|
protected static JSONObject settings = new JSONObject();
|
2014-11-04 14:48:14 +00:00
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
// Used to (un)bind the service to with the activity
|
2014-11-04 16:59:33 +00:00
|
|
|
private final ServiceConnection connection = new ServiceConnection() {
|
2014-10-26 15:47:18 +00:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onServiceConnected(ComponentName name, IBinder binder) {
|
|
|
|
// Nothing to do here
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void onServiceDisconnected(ComponentName name) {
|
2014-12-13 23:04:12 +00:00
|
|
|
// Nothing to do here
|
2014-10-26 15:47:18 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Executes the request.
|
|
|
|
*
|
|
|
|
* @param action The action to execute.
|
|
|
|
* @param args The exec() arguments.
|
|
|
|
* @param callback The callback context used when
|
|
|
|
* calling back into JavaScript.
|
|
|
|
*
|
|
|
|
* @return
|
|
|
|
* Returning false results in a "MethodNotFound" error.
|
|
|
|
*
|
|
|
|
* @throws JSONException
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public boolean execute (String action, JSONArray args,
|
2014-12-13 23:04:12 +00:00
|
|
|
CallbackContext callback) throws JSONException {
|
2014-10-26 15:47:18 +00:00
|
|
|
|
2014-11-04 14:48:14 +00:00
|
|
|
if (action.equalsIgnoreCase("configure")) {
|
2014-11-04 16:59:33 +00:00
|
|
|
setSettings(args.getJSONObject(0));
|
2014-11-17 13:19:29 +00:00
|
|
|
updateNotifcation();
|
2014-11-04 14:48:14 +00:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
if (action.equalsIgnoreCase("enable")) {
|
|
|
|
enableMode();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (action.equalsIgnoreCase("disable")) {
|
|
|
|
disableMode();
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the system is about to start resuming a previous activity.
|
|
|
|
*
|
|
|
|
* @param multitasking
|
|
|
|
* Flag indicating if multitasking is turned on for app
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public void onPause(boolean multitasking) {
|
|
|
|
super.onPause(multitasking);
|
|
|
|
inBackground = true;
|
|
|
|
startService();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called when the activity will start interacting with the user.
|
|
|
|
*
|
|
|
|
* @param multitasking
|
|
|
|
* Flag indicating if multitasking is turned on for app
|
|
|
|
*/
|
|
|
|
@Override
|
|
|
|
public void onResume(boolean multitasking) {
|
|
|
|
super.onResume(multitasking);
|
|
|
|
inBackground = false;
|
|
|
|
stopService();
|
|
|
|
}
|
|
|
|
|
2014-11-12 21:28:25 +00:00
|
|
|
/**
|
|
|
|
* Called when the activity will be destroyed.
|
|
|
|
*/
|
2014-10-26 15:47:18 +00:00
|
|
|
@Override
|
|
|
|
public void onDestroy() {
|
|
|
|
super.onDestroy();
|
|
|
|
stopService();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable the background mode.
|
|
|
|
*/
|
|
|
|
private void enableMode() {
|
|
|
|
isDisabled = false;
|
|
|
|
|
|
|
|
if (inBackground) {
|
|
|
|
startService();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Disable the background mode.
|
|
|
|
*/
|
|
|
|
private void disableMode() {
|
|
|
|
stopService();
|
|
|
|
isDisabled = true;
|
|
|
|
}
|
|
|
|
|
2014-11-04 16:59:33 +00:00
|
|
|
/**
|
2014-11-17 13:19:29 +00:00
|
|
|
* Update the settings for the notification.
|
2014-11-04 16:59:33 +00:00
|
|
|
*
|
2014-11-04 17:06:01 +00:00
|
|
|
* @param newSettings
|
|
|
|
* The new settings
|
2014-11-04 16:59:33 +00:00
|
|
|
*/
|
2014-11-04 17:06:01 +00:00
|
|
|
private void setSettings(JSONObject newSettings) {
|
|
|
|
settings = newSettings;
|
2014-11-17 13:19:29 +00:00
|
|
|
}
|
2014-11-04 16:59:33 +00:00
|
|
|
|
2014-11-17 13:19:29 +00:00
|
|
|
/**
|
|
|
|
* Update the notification.
|
|
|
|
*/
|
|
|
|
private void updateNotifcation() {
|
|
|
|
if (isBind) {
|
2014-11-04 16:59:33 +00:00
|
|
|
stopService();
|
|
|
|
startService();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
/**
|
|
|
|
* Bind the activity to a background service and put them into foreground
|
|
|
|
* state.
|
|
|
|
*/
|
|
|
|
private void startService() {
|
|
|
|
Activity context = cordova.getActivity();
|
|
|
|
|
|
|
|
Intent intent = new Intent(
|
|
|
|
context, ForegroundService.class);
|
|
|
|
|
2014-11-12 21:40:31 +00:00
|
|
|
if (isDisabled || isBind) {
|
2014-10-26 15:47:18 +00:00
|
|
|
return;
|
2014-11-04 16:59:33 +00:00
|
|
|
}
|
2014-10-26 15:47:18 +00:00
|
|
|
|
2014-12-13 23:04:12 +00:00
|
|
|
try {
|
|
|
|
context.bindService(
|
|
|
|
intent, connection, Context.BIND_AUTO_CREATE);
|
|
|
|
|
|
|
|
context.startService(intent);
|
2014-10-26 15:47:18 +00:00
|
|
|
|
2014-12-13 23:04:12 +00:00
|
|
|
fireEvent(Event.ACTIVATE, null);
|
|
|
|
} catch (Exception e) {
|
|
|
|
fireEvent(Event.FAILURE, e.getMessage());
|
|
|
|
}
|
2014-11-07 18:55:24 +00:00
|
|
|
|
|
|
|
isBind = true;
|
2014-10-26 15:47:18 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Bind the activity to a background service and put them into foreground
|
|
|
|
* state.
|
|
|
|
*/
|
|
|
|
private void stopService() {
|
|
|
|
Activity context = cordova.getActivity();
|
|
|
|
|
|
|
|
Intent intent = new Intent(
|
|
|
|
context, ForegroundService.class);
|
|
|
|
|
2014-11-07 18:55:24 +00:00
|
|
|
if (isBind) {
|
2014-12-13 23:04:12 +00:00
|
|
|
fireEvent(Event.DEACTIVATE, null);
|
2014-11-07 18:55:24 +00:00
|
|
|
context.unbindService(connection);
|
|
|
|
}
|
|
|
|
|
2014-10-26 15:47:18 +00:00
|
|
|
context.stopService(intent);
|
2014-11-07 18:55:24 +00:00
|
|
|
|
|
|
|
isBind = false;
|
2014-10-26 15:47:18 +00:00
|
|
|
}
|
2014-12-13 23:04:12 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Fire vent with some parameters inside the web view.
|
|
|
|
*
|
|
|
|
* @param event
|
|
|
|
* The name of the event
|
|
|
|
* @param params
|
|
|
|
* Optional arguments for the event
|
|
|
|
*/
|
|
|
|
private void fireEvent (Event event, String params) {
|
|
|
|
String eventName;
|
|
|
|
|
|
|
|
switch (event) {
|
|
|
|
case ACTIVATE:
|
|
|
|
eventName = "activate"; break;
|
|
|
|
case DEACTIVATE:
|
|
|
|
eventName = "deactivate"; break;
|
|
|
|
default:
|
|
|
|
eventName = "failure";
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
String js = String.format("setTimeout('cordova.plugins.backgroundMode" +
|
|
|
|
".on%s(%s)',0)",
|
|
|
|
eventName, params);
|
|
|
|
|
|
|
|
webView.loadUrl("javascript:" + js);
|
|
|
|
}
|
2014-10-26 15:47:18 +00:00
|
|
|
}
|