|
|
@@ -21,9 +21,6 @@
|
|
|
* @APPPLANT_LICENSE_HEADER_END@
|
|
|
*/
|
|
|
|
|
|
-var exec = require('cordova/exec'),
|
|
|
- channel = require('cordova/channel');
|
|
|
-
|
|
|
|
|
|
/*************
|
|
|
* INTERFACE *
|
|
|
@@ -35,7 +32,7 @@ var exec = require('cordova/exec'),
|
|
|
* @return {Object}
|
|
|
*/
|
|
|
exports.getDefaults = function () {
|
|
|
- return this._defaults;
|
|
|
+ return this.core.getDefaults();
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -43,14 +40,8 @@ exports.getDefaults = function () {
|
|
|
*
|
|
|
* @param {Object} defaults
|
|
|
*/
|
|
|
-exports.setDefaults = function (newDefaults) {
|
|
|
- var defaults = this.getDefaults();
|
|
|
-
|
|
|
- for (var key in defaults) {
|
|
|
- if (newDefaults.hasOwnProperty(key)) {
|
|
|
- defaults[key] = newDefaults[key];
|
|
|
- }
|
|
|
- }
|
|
|
+exports.setDefaults = function (defaults) {
|
|
|
+ this.core.setDefaults(defaults);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -64,22 +55,7 @@ exports.setDefaults = function (newDefaults) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.schedule = function (opts, callback, scope) {
|
|
|
- this.registerPermission(function(granted) {
|
|
|
-
|
|
|
- if (!granted)
|
|
|
- return;
|
|
|
-
|
|
|
- var notifications = Array.isArray(opts) ? opts : [opts];
|
|
|
-
|
|
|
- for (var i = 0; i < notifications.length; i++) {
|
|
|
- var properties = notifications[i];
|
|
|
-
|
|
|
- this.mergeWithDefaults(properties);
|
|
|
- this.convertProperties(properties);
|
|
|
- }
|
|
|
-
|
|
|
- this.exec('schedule', notifications, callback, scope);
|
|
|
- }, this);
|
|
|
+ this.core.schedule(opts, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -93,15 +69,7 @@ exports.schedule = function (opts, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.update = function (opts, callback, scope) {
|
|
|
- var notifications = Array.isArray(opts) ? opts : [opts];
|
|
|
-
|
|
|
- for (var i = 0; i < notifications.length; i++) {
|
|
|
- var properties = notifications[i];
|
|
|
-
|
|
|
- this.convertProperties(properties);
|
|
|
- }
|
|
|
-
|
|
|
- this.exec('update', notifications, callback, scope);
|
|
|
+ this.core.update(opts, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -115,11 +83,7 @@ exports.update = function (opts, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.clear = function (ids, callback, scope) {
|
|
|
- ids = Array.isArray(ids) ? ids : [ids];
|
|
|
-
|
|
|
- ids = this.convertIds(ids);
|
|
|
-
|
|
|
- this.exec('clear', ids, callback, scope);
|
|
|
+ this.core.clear(ids, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -131,7 +95,7 @@ exports.clear = function (ids, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.clearAll = function (callback, scope) {
|
|
|
- this.exec('clearAll', null, callback, scope);
|
|
|
+ this.core.clearAll(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -145,12 +109,7 @@ exports.clearAll = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.cancel = function (ids, callback, scope) {
|
|
|
-
|
|
|
- ids = Array.isArray(ids) ? ids : [ids];
|
|
|
-
|
|
|
- ids = this.convertIds(ids);
|
|
|
-
|
|
|
- this.exec('cancel', ids, callback, scope);
|
|
|
+ this.core.cancel(ids, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -162,7 +121,7 @@ exports.cancel = function (ids, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.cancelAll = function (callback, scope) {
|
|
|
- this.exec('cancelAll', null, callback, scope);
|
|
|
+ this.core.cancelAll(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -176,9 +135,7 @@ exports.cancelAll = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.isPresent = function (id, callback, scope) {
|
|
|
- var notId = (id || '0').toString();
|
|
|
-
|
|
|
- this.exec('isPresent', notId, callback, scope);
|
|
|
+ this.core.isPresent(id, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -192,9 +149,7 @@ exports.isPresent = function (id, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.isScheduled = function (id, callback, scope) {
|
|
|
- var notId = (id || '0').toString();
|
|
|
-
|
|
|
- this.exec('isScheduled', notId, callback, scope);
|
|
|
+ this.core.isScheduled(id, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -208,9 +163,7 @@ exports.isScheduled = function (id, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.isTriggered = function (id, callback, scope) {
|
|
|
- var notId = (id || '0').toString();
|
|
|
-
|
|
|
- this.exec('isTriggered', notId, callback, scope);
|
|
|
+ this.core.isTriggered(id, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -222,7 +175,7 @@ exports.isTriggered = function (id, callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getAllIds = function (callback, scope) {
|
|
|
- this.exec('getAllIds', null, callback, scope);
|
|
|
+ this.core.getAllIds(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -241,7 +194,7 @@ exports.getIds = function () {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getScheduledIds = function (callback, scope) {
|
|
|
- this.exec('getScheduledIds', null, callback, scope);
|
|
|
+ this.core.getScheduledIds(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -253,7 +206,7 @@ exports.getScheduledIds = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getTriggeredIds = function (callback, scope) {
|
|
|
- this.exec('getTriggeredIds', null, callback, scope);
|
|
|
+ this.core.getTriggeredIds(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -268,23 +221,7 @@ exports.getTriggeredIds = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.get = function () {
|
|
|
- var args = Array.apply(null, arguments);
|
|
|
-
|
|
|
- if (typeof args[0] == 'function') {
|
|
|
- args.unshift([]);
|
|
|
- }
|
|
|
-
|
|
|
- var ids = args[0],
|
|
|
- callback = args[1],
|
|
|
- scope = args[2];
|
|
|
-
|
|
|
- if (!Array.isArray(ids)) {
|
|
|
- ids = [ids];
|
|
|
- }
|
|
|
-
|
|
|
- ids = this.convertIds(ids);
|
|
|
-
|
|
|
- this.exec('getAll', ids, callback, scope);
|
|
|
+ this.core.get.apply(this.core, arguments);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -296,7 +233,7 @@ exports.get = function () {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getAll = function (callback, scope) {
|
|
|
- this.exec('getAll', null, callback, scope);
|
|
|
+ this.core.getAll(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -311,23 +248,7 @@ exports.getAll = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getScheduled = function () {
|
|
|
- var args = Array.apply(null, arguments);
|
|
|
-
|
|
|
- if (typeof args[0] == 'function') {
|
|
|
- args.unshift([]);
|
|
|
- }
|
|
|
-
|
|
|
- var ids = args[0],
|
|
|
- callback = args[1],
|
|
|
- scope = args[2];
|
|
|
-
|
|
|
- if (!Array.isArray(ids)) {
|
|
|
- ids = [ids];
|
|
|
- }
|
|
|
-
|
|
|
- ids = this.convertIds(ids);
|
|
|
-
|
|
|
- this.exec('getScheduled', ids, callback, scope);
|
|
|
+ this.core.getScheduled.apply(this.core, arguments);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -339,7 +260,7 @@ exports.getScheduled = function () {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getAllScheduled = function (callback, scope) {
|
|
|
- this.exec('getScheduled', null, callback, scope);
|
|
|
+ this.core.getAllScheduled(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -354,23 +275,7 @@ exports.getAllScheduled = function (callback, scope) {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getTriggered = function () {
|
|
|
- var args = Array.apply(null, arguments);
|
|
|
-
|
|
|
- if (typeof args[0] == 'function') {
|
|
|
- args.unshift([]);
|
|
|
- }
|
|
|
-
|
|
|
- var ids = args[0],
|
|
|
- callback = args[1],
|
|
|
- scope = args[2];
|
|
|
-
|
|
|
- if (!Array.isArray(ids)) {
|
|
|
- ids = [ids];
|
|
|
- }
|
|
|
-
|
|
|
- ids = this.convertIds(ids);
|
|
|
-
|
|
|
- this.exec('getTriggered', ids, callback, scope);
|
|
|
+ this.core.getTriggered.apply(this.core, arguments);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -382,7 +287,7 @@ exports.getTriggered = function () {
|
|
|
* The scope for the callback function
|
|
|
*/
|
|
|
exports.getAllTriggered = function (callback, scope) {
|
|
|
- this.exec('getTriggered', null, callback, scope);
|
|
|
+ this.core.getAllTriggered(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -394,14 +299,7 @@ exports.getAllTriggered = function (callback, scope) {
|
|
|
* The callback function's scope
|
|
|
*/
|
|
|
exports.hasPermission = function (callback, scope) {
|
|
|
- var fn = this.createCallbackFn(callback, scope);
|
|
|
-
|
|
|
- if (device.platform != 'iOS') {
|
|
|
- fn(true);
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- exec(fn, null, 'LocalNotification', 'hasPermission', []);
|
|
|
+ this.core.hasPermission(callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -413,14 +311,7 @@ exports.hasPermission = function (callback, scope) {
|
|
|
* The callback function's scope
|
|
|
*/
|
|
|
exports.registerPermission = function (callback, scope) {
|
|
|
- var fn = this.createCallbackFn(callback, scope);
|
|
|
-
|
|
|
- if (device.platform != 'iOS') {
|
|
|
- fn(true);
|
|
|
- return;
|
|
|
- }
|
|
|
-
|
|
|
- exec(fn, null, 'LocalNotification', 'registerPermission', []);
|
|
|
+ this.core.registerPermission(callback, scope);
|
|
|
};
|
|
|
|
|
|
|
|
|
@@ -434,7 +325,7 @@ exports.registerPermission = function (callback, scope) {
|
|
|
exports.add = function () {
|
|
|
console.warn('Depreated: Please use `notification.local.schedule` instead.');
|
|
|
|
|
|
- exports.schedule.apply(this, arguments);
|
|
|
+ this.schedule.apply(this, arguments);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -444,7 +335,7 @@ exports.add = function () {
|
|
|
exports.promptForPermission = function () {
|
|
|
console.warn('Depreated: Please use `notification.local.registerPermission` instead.');
|
|
|
|
|
|
- exports.registerPermission.apply(this, arguments);
|
|
|
+ this.registerPermission.apply(this, arguments);
|
|
|
};
|
|
|
|
|
|
|
|
|
@@ -463,14 +354,7 @@ exports.promptForPermission = function () {
|
|
|
* The callback function's scope
|
|
|
*/
|
|
|
exports.on = function (event, callback, scope) {
|
|
|
-
|
|
|
- if (!this._listener[event]) {
|
|
|
- this._listener[event] = [];
|
|
|
- }
|
|
|
-
|
|
|
- var item = [callback, scope || window];
|
|
|
-
|
|
|
- this._listener[event].push(item);
|
|
|
+ this.core.on(event, callback, scope);
|
|
|
};
|
|
|
|
|
|
/**
|
|
|
@@ -482,274 +366,5 @@ exports.on = function (event, callback, scope) {
|
|
|
* The function to be exec as callback
|
|
|
*/
|
|
|
exports.un = function (event, callback) {
|
|
|
- var listener = this._listener[event];
|
|
|
-
|
|
|
- if (!listener)
|
|
|
- return;
|
|
|
-
|
|
|
- for (var i = 0; i < listener.length; i++) {
|
|
|
- var fn = listener[i][0];
|
|
|
-
|
|
|
- if (fn == callback) {
|
|
|
- listener.splice(i, 1);
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
+ this.core.un(event, callback, scope);
|
|
|
};
|
|
|
-
|
|
|
-
|
|
|
-/***********
|
|
|
- * MEMBERS *
|
|
|
- ***********/
|
|
|
-
|
|
|
-// Default values
|
|
|
-exports._defaults = {
|
|
|
- text: '',
|
|
|
- title: '',
|
|
|
- sound: 'res://platform_default',
|
|
|
- badge: 0,
|
|
|
- id: "0",
|
|
|
- data: undefined,
|
|
|
- every: undefined,
|
|
|
- at: undefined
|
|
|
-};
|
|
|
-
|
|
|
-// listener
|
|
|
-exports._listener = {};
|
|
|
-
|
|
|
-
|
|
|
-/***********
|
|
|
- * PRIVATE *
|
|
|
- ***********/
|
|
|
-
|
|
|
-/**
|
|
|
- * Merge custom properties with the default values.
|
|
|
- *
|
|
|
- * @param {Object} options
|
|
|
- * Set of custom values
|
|
|
- *
|
|
|
- * @retrun {Object}
|
|
|
- * The merged property list
|
|
|
- */
|
|
|
-exports.mergeWithDefaults = function (options) {
|
|
|
- var defaults = this.getDefaults();
|
|
|
-
|
|
|
- options.at = this.getValueFor(options, 'at', 'firstAt', 'date');
|
|
|
- options.text = this.getValueFor(options, 'text', 'message');
|
|
|
- options.data = this.getValueFor(options, 'data', 'json');
|
|
|
-
|
|
|
- if (options.at === undefined || options.at === null) {
|
|
|
- options.at = new Date();
|
|
|
- }
|
|
|
-
|
|
|
- for (var key in defaults) {
|
|
|
- if (options[key] === null || options[key] === undefined) {
|
|
|
- if (options.hasOwnProperty(key) && ['data','sound'].indexOf(key) > -1) {
|
|
|
- options[key] = undefined;
|
|
|
- } else {
|
|
|
- options[key] = defaults[key];
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- for (key in options) {
|
|
|
- if (!defaults.hasOwnProperty(key)) {
|
|
|
- delete options[key];
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- return options;
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Convert the passed values to their required type.
|
|
|
- *
|
|
|
- * @param {Object} options
|
|
|
- * Set of custom values
|
|
|
- *
|
|
|
- * @retrun {Object}
|
|
|
- * The converted property list
|
|
|
- */
|
|
|
-exports.convertProperties = function (options) {
|
|
|
-
|
|
|
- if (options.id) {
|
|
|
- if (isNaN(options.id)) {
|
|
|
- options.id = this.getDefaults().id;
|
|
|
- } else {
|
|
|
- options.id = options.id.toString();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- if (options.title) {
|
|
|
- options.title = options.title.toString();
|
|
|
- }
|
|
|
-
|
|
|
- if (options.text) {
|
|
|
- options.text = options.text.toString();
|
|
|
- }
|
|
|
-
|
|
|
- if (options.badge) {
|
|
|
- if (isNaN(options.badge)) {
|
|
|
- options.badge = this.getDefaults().badge;
|
|
|
- } else {
|
|
|
- options.badge = Number(options.badge);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- if (typeof options.at == 'object') {
|
|
|
- options.at = Math.round(options.at.getTime()/1000);
|
|
|
- }
|
|
|
-
|
|
|
- if (typeof options.data == 'object') {
|
|
|
- options.data = JSON.stringify(options.data);
|
|
|
- }
|
|
|
-
|
|
|
- return options;
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Merge platform specific properties into the default ones.
|
|
|
- *
|
|
|
- * @return {Object}
|
|
|
- * The default properties for the platform
|
|
|
- */
|
|
|
-exports.applyPlatformSpecificOptions = function () {
|
|
|
- var defaults = this._defaults;
|
|
|
-
|
|
|
- switch (device.platform) {
|
|
|
- case 'Android':
|
|
|
- defaults.icon = 'res://icon';
|
|
|
- defaults.smallIcon = 'res://ic_popup_reminder';
|
|
|
- defaults.ongoing = false;
|
|
|
- defaults.led = 'FFFFFF';
|
|
|
- break;
|
|
|
- }
|
|
|
-
|
|
|
- return defaults;
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Create callback, which will be executed within a specific scope.
|
|
|
- *
|
|
|
- * @param {Function} callbackFn
|
|
|
- * The callback function
|
|
|
- * @param {Object} scope
|
|
|
- * The scope for the function
|
|
|
- *
|
|
|
- * @return {Function}
|
|
|
- * The new callback function
|
|
|
- */
|
|
|
-exports.createCallbackFn = function (callbackFn, scope) {
|
|
|
- if (typeof callbackFn != 'function')
|
|
|
- return;
|
|
|
-
|
|
|
- return function () {
|
|
|
- callbackFn.apply(scope || this, arguments);
|
|
|
- };
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Convert the IDs to Strings.
|
|
|
- *
|
|
|
- * @param {String/Number[]} ids
|
|
|
- *
|
|
|
- * @return Array of Strings
|
|
|
- */
|
|
|
-exports.convertIds = function (ids) {
|
|
|
- var convertedIds = [];
|
|
|
-
|
|
|
- for (var i = 0; i < ids.length; i++) {
|
|
|
- convertedIds.push(ids[i].toString());
|
|
|
- }
|
|
|
-
|
|
|
- return convertedIds;
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * First found value for the given keys.
|
|
|
- *
|
|
|
- * @param {Object} options
|
|
|
- * Object with key-value properties
|
|
|
- * @param {String[]} keys*
|
|
|
- * Key list
|
|
|
- */
|
|
|
-exports.getValueFor = function (options) {
|
|
|
- var keys = Array.apply(null, arguments).slice(1);
|
|
|
-
|
|
|
- for (var i = 0; i < keys.length; i++) {
|
|
|
- var key = keys[i];
|
|
|
-
|
|
|
- if (options.hasOwnProperty(key)) {
|
|
|
- return options[key];
|
|
|
- }
|
|
|
- }
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Fire event with given arguments.
|
|
|
- *
|
|
|
- * @param {String} event
|
|
|
- * The event's name
|
|
|
- * @param {args*}
|
|
|
- * The callback's arguments
|
|
|
- */
|
|
|
-exports.fireEvent = function (event) {
|
|
|
- var args = Array.apply(null, arguments).slice(1),
|
|
|
- listener = this._listener[event];
|
|
|
-
|
|
|
- if (!listener)
|
|
|
- return;
|
|
|
-
|
|
|
- for (var i = 0; i < listener.length; i++) {
|
|
|
- var fn = listener[i][0],
|
|
|
- scope = listener[i][1];
|
|
|
-
|
|
|
- fn.apply(scope, args);
|
|
|
- }
|
|
|
-};
|
|
|
-
|
|
|
-/**
|
|
|
- * Execute the native counterpart.
|
|
|
- *
|
|
|
- * @param {String} action
|
|
|
- * The name of the action
|
|
|
- * @param args[]
|
|
|
- * Array of arguments
|
|
|
- * @param {Function} callback
|
|
|
- * The callback function
|
|
|
- * @param {Object} scope
|
|
|
- * The scope for the function
|
|
|
- */
|
|
|
-exports.exec = function (action, args, callback, scope) {
|
|
|
- var fn = this.createCallbackFn(callback, scope),
|
|
|
- params = [];
|
|
|
-
|
|
|
- if (Array.isArray(args)) {
|
|
|
- params = args;
|
|
|
- } else if (args) {
|
|
|
- params.push(args);
|
|
|
- }
|
|
|
-
|
|
|
- exec(fn, null, 'LocalNotification', action, params);
|
|
|
-};
|
|
|
-
|
|
|
-
|
|
|
-/*********
|
|
|
- * HOOKS *
|
|
|
- *********/
|
|
|
-
|
|
|
-// Called after 'deviceready' event
|
|
|
-channel.deviceready.subscribe(function () {
|
|
|
- // Device is ready now, the listeners are registered
|
|
|
- // and all queued events can be executed.
|
|
|
- exec(null, null, 'LocalNotification', 'deviceready', []);
|
|
|
-});
|
|
|
-
|
|
|
-// Called before 'deviceready' event
|
|
|
-channel.onCordovaReady.subscribe(function () {
|
|
|
- // Device plugin is ready now
|
|
|
- channel.onCordovaInfoReady.subscribe(function () {
|
|
|
- // Merge platform specifics into defaults
|
|
|
- exports.applyPlatformSpecificOptions();
|
|
|
- });
|
|
|
-});
|