From 210e8feae2fb4842bfb2de38666e6c41671fef3c Mon Sep 17 00:00:00 2001 From: Pliable Pixels Date: Wed, 27 Sep 2017 12:42:48 -0400 Subject: removed lib --- www/lib/ngCordova/dist/ng-cordova-mocks.js | 3486 ---------------------------- 1 file changed, 3486 deletions(-) delete mode 100644 www/lib/ngCordova/dist/ng-cordova-mocks.js (limited to 'www/lib/ngCordova/dist/ng-cordova-mocks.js') diff --git a/www/lib/ngCordova/dist/ng-cordova-mocks.js b/www/lib/ngCordova/dist/ng-cordova-mocks.js deleted file mode 100644 index 892f71cb..00000000 --- a/www/lib/ngCordova/dist/ng-cordova-mocks.js +++ /dev/null @@ -1,3486 +0,0 @@ -/*! - * ngCordova - * v0.1.27-alpha - * Copyright 2015 Drifty Co. http://drifty.com/ - * See LICENSE in this repository for license information - */ -(function(){ -var ngCordovaMocks = angular.module('ngCordovaMocks', []); -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaActionSheet - * - * @description - * A service for testing action sheet - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaActionSheet', ['$q', function ($q) { - var throwsError = false; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaActionSheet - * @type Boolean - * - * @description - * A flag that signals whether a promise should be rejected. - * This property should only be used in automated tests - */ - throwsError: throwsError, - - show: function () { - var defer = $q.defer(); - - if (this.throwsError) { - defer.reject('There was an error on showing action sheet'); - } else { - defer.resolve(); - } - - return defer.promise; - } - }; -}]); - -ngCordovaMocks.factory('$cordovaAppVersion', ['$q', function ($q) { - var throwsError = false; - return { - throwsError: throwsError, - - getAppName: function () { - var q = $q.defer(); - q.resolve('mock app name'); - return q.promise; - }, - - getPackageName: function () { - var q = $q.defer(); - q.resolve('com.package.mock'); - return q.promise; - }, - - getVersionNumber: function () { - var q = $q.defer(); - q.resolve('1.2.3'); - return q.promise; - }, - - getVersionCode: function () { - var q = $q.defer(); - q.resolve('4.5.6'); - return q.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaBarcodeScanner - * - * @description - * A service for testing barcode scanner features - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaBarcodeScanner', ['$q', function ($q) { - var throwsError = false; - - var scannedText = ''; - var scannedFormat = ''; - var wasCancelled = false; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaBarcodeScanner - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name scannedText - * @propertyOf ngCordovaMocks.cordovaBarcodeScanner - * - * @description - * Used to simulate the result.text property of a - * successful scan. For more information, see the text at - * https://github.com/wildabeast/BarcodeScanner/#using-the-plugin - * This property should only be used in automated tests. - **/ - scannedText: scannedText, - - /** - * @ngdoc property - * @name scannedFormat - * @propertyOf ngCordovaMocks.cordovaBarcodeScanner - * @description - * Used to simulate the result.format property of a - * successful scan. For more information, see the text at - * https://github.com/wildabeast/BarcodeScanner/#using-the-plugin - * This property should only be used in automated tests. - **/ - scannedFormat: scannedFormat, - - /** - * @ngdoc property - * @name wasCancelled - * @propertyOf ngCordovaMocks.cordovaBarcodeScanner - * - * @description - * Used to simulate the result.cancelled property of a - * successful scan. For more information, see the text at - * https://github.com/wildabeast/BarcodeScanner/#using-the-plugin - * This property should only be used in automated tests. - **/ - wasCancelled: wasCancelled, - - scan: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error scanning.'); - } else { - defer.resolve({text: this.scannedText, format: this.scannedFormat, cancelled: this.wasCancelled}); - } - - return defer.promise; - }, - - encode: function (type, data) { - this.scannedFormat = type; - this.scannedText = data; - - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error encoding the data.'); - } else { - defer.resolve(); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaBLE - * - * @description - * A service for ble features - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaBLE', ['$q', '$timeout', '$interval', '$log', function ($q, $timeout, $interval, $log) { - var deviceScan = { - name: 'Test Device', - id: 'AA:BB:CC:DD:EE:FF', - advertising: [2, 1, 6, 3, 3, 15, 24, 8, 9, 66, 97, 116, 116, 101, 114, 121], - rssi: -55 - }; - - var deviceConnect = { - name: 'Test Device', - id: 'AA:BB:CC:DD:EE:FF', - advertising: [2, 1, 6, 3, 3, 15, 24, 8, 9, 66, 97, 116, 116, 101, 114, 121], - rssi: -55, - services: [ - '1800', - '1801', - '180f' - ], - characteristics: [ - { - service: '1800', - characteristic: '2a00', - properties: ['Read'] - }, - { - service: '1800', - characteristic: '2a01', - properties: ['Read'] - }, - { - service: '1801', - characteristic: '2a05', - properties: ['Read'] - }, - { - service: '180f', - characteristic: '2a19', - properties: ['Read'], - descriptors: [{'uuid': '2901'}, {'uuid': '2904'}] - } - ] - }; - - var readData = new ArrayBuffer(8); - - return { - - scan: function (services, seconds) { - var q = $q.defer(); - - // first notify about discovered device - $timeout(function () { - q.notify(deviceScan); - }, Math.round(seconds * 1000 * Math.random())); - - // end scan - $timeout(function () { - q.resolve(); - }, seconds * 1000); - - return q.promise; - }, - - startScan: function (services, callback, errorCallback) { - $timeout(function () { - callback(deviceScan); - }, Math.round(1000 * Math.random())); - }, - - stopScan: function () { - var q = $q.defer(); - $timeout(function () { - q.resolve(); - }, 500); - return q.promise; - }, - - connect: function (deviceID) { - var q = $q.defer(); - $timeout(function () { - q.resolve(deviceConnect); - }, 1500); - return q.promise; - }, - - disconnect: function (deviceID) { - var q = $q.defer(); - $timeout(function () { - q.resolve(true); - }, 500); - return q.promise; - }, - - read: function (deviceID, serviceUUID, characteristicUUID) { - var q = $q.defer(); - $timeout(function () { - q.resolve(readData); - }, 100); - return q.promise; - }, - - write: function (deviceID, serviceUUID, characteristicUUID, data) { - var q = $q.defer(); - $timeout(function () { - q.resolve(true); - }, 100); - return q.promise; - }, - - writeWithoutResponse: function (deviceID, serviceUUID, characteristicUUID, data) { - var q = $q.defer(); - $timeout(function () { - q.resolve(true); - }, 100); - return q.promise; - }, - - writeCommand: function (deviceID, serviceUUID, characteristicUUID, data) { - $log.warning('writeCommand is deprecated, use writeWithoutResponse'); - return this.writeWithoutResponse(deviceID, serviceUUID, characteristicUUID, data); - }, - - startNotification: function (deviceID, serviceUUID, characteristicUUID, callback, errorCallback) { - $interval(function () { - var data = new Uint8Array([Math.round(255 * Math.random())]); // one byte with random number - callback(data); - }, 200, 10); // repeat 10 times with 200 ms delay for each - }, - - stopNotification: function (deviceID, serviceUUID, characteristicUUID) { - var q = $q.defer(); - $timeout(function () { - q.resolve(); - }, 100); - return q.promise; - }, - - isConnected: function (deviceID) { - var q = $q.defer(); - q.resolve(true); - return q.promise; - }, - - enable: function () { - var q = $q.defer(); - $timeout(function () { - q.resolve(); - }, 1500); - return q.promise; - }, - - isEnabled: function () { - var q = $q.defer(); - q.resolve(true); - return q.promise; - } - }; -}]); - -ngCordovaMocks.factory('$cordovaBrightness', ['$q', function ($q) { - var currentBrightness = 100; - - return { - get: function () { - var q = $q.defer(); - q.resolve(currentBrightness); - return q.promise; - }, - - set: function (data) { - var q = $q.defer(); - currentBrightness = data; - q.resolve('OK'); - return q.promise; - }, - - setKeepScreenOn: function (bool) { - var q = $q.defer(); - q.resolve('OK'); - return q.promise; - } - }; -}]); -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaCamera - * - * @description - * A service for testing camera features - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaCamera', ['$q', function ($q) { - var throwsError = false; - var imageData = ''; - - return { - - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaCamera - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name imageData - * @propertyOf ngCordovaMocks.cordovaCamera - * - * @description - * The imagedata (e.g. an url) which will be returned from the device. - * This property should only be used in automated tests. - **/ - imageData: imageData, - - getPicture: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the picture.'); - } else { - if (options) { - options = options; // This is just to get by JSHint. - } - - defer.resolve(this.imageData); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaCapture - * - * @description - * A service for testing media capture - * in an app build with ngCordova. - * - * @example - */ -ngCordovaMocks.factory('$cordovaCapture', ['$q', function ($q) { - var throwsError = false; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaCapture - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - captureAudio: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error capturing the audio.'); - } else { - defer.resolve(); - } - - return defer.promise; - }, - - captureImage: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error capturing the image.'); - } else { - defer.resolve(); - } - - return defer.promise; - }, - - captureVideo: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error capturing the video.'); - } else { - defer.resolve(); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaContacts - * - * @description - * A service for testing features related with contacts - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaContacts', ['$q', function ($q) { - var throwsError = false; - var contacts = []; - - return { - /** - @ngdoc property - @name throwsError - @propertyOf ngCordovaMocks.cordovaContacts - - @description - A flag that signals whether a promise should be rejected or not. - This property should only be used in automated tests. - */ - throwsError: throwsError, - - /** - @ngdoc contacts - @name throwsError - @propertyOf ngCordovaMocks.cordovaContacts - - @description - An in-memory collection of contacts. - This property should only be used in automated tests. - */ - contacts: contacts, - - save: function (contact) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error saving the contact.'); - } else { - var existingIndex = null; - for (var i = 0; i < this.contacts.length; i++) { - // The actual implementation relies on the entire object match. - // we're gong to rely on the ID. - if (this.contacts[i].id === contact.id) { - existingIndex = i; - break; - } - } - - if (existingIndex === null) { - this.contacts.push(contact); - defer.resolve(); - } else { - defer.reject('Contact already exists.'); - } - } - - return defer.promise; - }, - - remove: function (contact) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error saving the contact.'); - } else { - var toRemove = null; - for (var i = 0; i < this.contacts.length; i++) { - // The actual implementation relies on the entire object match. - // we're gong to rely on the ID. - if (this.contacts[i].id === contact.id) { - toRemove = i; - break; - } - } - - if (toRemove === null) { - defer.reject('Unable to find contact.'); - } else { - this.contacts.splice(toRemove, 1); - defer.resolve(); - } - } - - return defer.promise; - }, - - find: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error finding the contact.'); - } else { - var fields = options.fields || ['id', 'displayName']; - delete options.fields; - - if (!fields) { - defer.reject('ContactError.INVALID_ARGUMENT_ERROR'); - } else { - if (fields === '*') { - defer.resolve(this.contacts); - } else { - // Implement a very rudimentary search approach for testing purposes. - // This is NOT exhaustive. - var results = []; - for (var i = 0; i < this.contacts.length; i++) { - for (var key in this.contacts[i]) { - var propertyValue = this.contacts[i][key]; - } - } - - // TODO: Search by individual fields - defer.resolve(results); - } - } - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaDatePicker - * - * @description - * A service for testing datepicker features - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaDatePicker', ['$q', function ($q) { - return { - show: function (options) { - var q = $q.defer(); - options = options || {date: new Date(), mode: 'date'}; - q.resolve(options.date); - return q.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaDevice - * - * @description - * A service for testing device information - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaDevice', function () { - var device = ''; - var cordova = ''; - var model = ''; - var platform = ''; - var uuid = ''; - var version = ''; - - return { - /** - @ngdoc property - @name device - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The name of the 'device'. - This property should only be used in automated tests. - */ - device: device, - - /** - @ngdoc property - @name cordova - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The version of cordova in use. - This property should only be used in automated tests. - */ - cordova: cordova, - - /** - @ngdoc property - @name model - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The model of the device using the app. - This property should only be used in automated tests. - */ - model: model, - - /** - @ngdoc property - @name platform - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The name of the operating system in use. - This property should only be used in automated tests. - */ - platform: platform, - - /** - @ngdoc property - @name uuid - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The unique identifier of a device. - This property should only be used in automated tests. - */ - uuid: uuid, - - /** - @ngdoc property - @name version - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The version of the operating system. - This property should only be used in automated tests. - */ - version: version, - - /** - @ngdoc property - @name manufacturer - @propertyOf ngCordovaMocks.cordovaDevice - - @description - The manufacturer of the device. - This property should only be used in automated tests. - */ - version: version, - - getDevice: function () { - return this.device; - }, - - getCordova: function () { - return this.cordova; - }, - - getModel: function () { - return this.model; - }, - - getPlatform: function () { - return this.platform; - }, - - getUUID: function () { - return this.uuid; - }, - - getVersion: function () { - return this.version; - }, - - getManufacturer: function () { - return this.manufacturer; - } - }; -}); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaDeviceMotion - * - * @description - * A service for mocking the accelerometer - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaDeviceMotion', ['$interval', '$q', function ($interval, $q) { - var currentAcceleration = null; - var throwsError = false; - var positions = []; - var watchIntervals = []; - - return { - /** - * @ngdoc property - * @name currentAcceleration - * @propertyOf ngCordovaMocks.cordovaDeviceMotion - * - * @description - * The current acceleration. - * This property should only be used in automated tests. - **/ - currentAcceleration: currentAcceleration, - - /** - @ngdoc property - @name throwsError - @propertyOf ngCordovaMocks.cordovaDeviceMotion - - @description - A flag that signals whether a promise should be rejected or not. - This property should only be used in automated tests. - */ - throwsError: throwsError, - - /** - @ngdoc property - @name positions - @propertyOf ngCordovaMocks.cordovaDeviceMotion - - @description - The collection of 'positions' that have been logged. - This property should only be used in automated tests. - */ - positions: positions, - - /** - @ngdoc property - @name watchIntervals - @propertyOf ngCordovaMocks.cordovaDeviceMotion - - @description - The collection of watchers that are currently active. - This property should only be used in automated tests. - */ - watchIntervals: watchIntervals, - - getCurrentAcceleration: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the current acceleration.'); - } else { - defer.resolve(this.currentAcceleration); - } - - return defer.promise; - }, - - watchAcceleration: function (options) { - var defer = $q.defer(); - var watchId = Math.floor((Math.random() * 1000000) + 1); - - this.positions = []; - self = this; - - if (this.throwsError) { - defer.reject('There was an error watching the current acceleration.'); - } else { - var delay = 10000; // The default based on https://github.com/apache/cordova-plugin-device-motion - if (options && options.frequency) { - delay = options.frequency; - } - - this.watchIntervals.push($interval( - function () { - if (self.throwsError) { - defer.reject('There was an error watching the acceleration.'); - } - - // Generate a random position - var randomX = Math.floor((Math.random() * 100) + 1); - var randomY = Math.floor((Math.random() * 100) + 1); - var randomZ = Math.floor((Math.random() * 100) + 1); - var result = {x: randomX, y: randomY, z: randomZ, timestamp: Date.now()}; - - self.positions.push(result); - defer.notify(result); - }, - delay - )); - } - - return { - watchId: watchId, - promise: defer.promise - }; - }, - - clearWatch: function (watchId) { - var defer = $q.defer(); - if (watchId) { - if (this.throwsError) { - defer.reject('Unable to clear watch.'); - } else { - var removed = -1; - for (var i = 0; i < this.watchIntervals.length; i++) { - if (this.watchIntervals[i].watchId === watchId) { - $interval.cancel(watchIntervals[i].interval); - removed = i; - break; - } - } - - if (removed !== -1) { - this.watchIntervals.splice(removed, 1); - } - } - } else { - defer.reject('Unable to clear watch. No watch ID provided.'); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaDeviceOrientation - * - * @description - * A service for testing compass fetures - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaDeviceOrientation', ['$interval', '$q', function ($interval, $q) { - var currentHeading = null; - var throwsError = false; - var readings = []; - var watchIntervals = []; - - return { - /** - * @ngdoc property - * @name currentHeading - * @propertyOf ngCordovaMocks.cordovaDeviceOrientation - * - * @description - * The current heading. - * This property should only be used in automated tests. - **/ - currentHeading: currentHeading, - - /** - @ngdoc property - @name throwsError - @propertyOf ngCordovaMocks.cordovaDeviceOrientation - - @description - A flag that signals whether a promise should be rejected or not. - This property should only be used in automated tests. - */ - throwsError: throwsError, - - /** - @ngdoc property - @name positions - @propertyOf ngCordovaMocks.cordovaDeviceOrientation - - @description - The collection of compass 'readings' that have been logged. - This property should only be used in automated tests. - */ - readings: readings, - - /** - @ngdoc property - @name watchIntervals - @propertyOf ngCordovaMocks.cordovaDeviceOrientation - - @description - The collection of watchers that are currently active. - This property should only be used in automated tests. - */ - watchIntervals: watchIntervals, - - getCurrentHeading: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the current heading.'); - } else { - defer.resolve(this.currentHeading); - } - - return defer.promise; - }, - - watchHeading: function (options) { - var defer = $q.defer(); - var watchID = Math.floor((Math.random() * 1000000) + 1); - var self = this; - - self.readings = []; - - if (self.throwsError) { - defer.reject('There was an error getting the compass heading.'); - } else { - var delay = 100; // The default based on https://github.com/apache/cordova-plugin-device-orientation - if (options && options.frequency) { - delay = options.frequency; - } - - self.watchIntervals.push({ - watchID: watchID, - interval: $interval( - function () { - if (self.throwsError) { - defer.reject('There was an error watching the acceleration.'); - } - - // Generate a random position - var magneticHeading = (Math.random() * 359.99) + 1; - var trueHeading = (Math.random() * 359.99) + 1; - var headingAccuracy = Math.floor((Math.random() * 360) + 1); - var result = {magneticHeading: magneticHeading, trueHeading: trueHeading, headingAccuracy: headingAccuracy, timestamp: Date.now()}; - - self.readings.push(result); - defer.notify(result); - }, - delay - ) - }); - } - - var cancel = function (id) { - var removed = -1; - for (var i = 0; i < self.watchIntervals.length; i++) { - if (self.watchIntervals[i].watchID === id) { - $interval.cancel(watchIntervals[i].interval); - removed = i; - break; - } - } - - if (removed !== -1) { - self.watchIntervals.splice(removed, 1); - } - }; - - defer.promise.cancel = function () { - cancel(watchID); - }; - - defer.promise.clearWatch = function (id) { - cancel(id || watchID); - }; - - defer.promise.watchID = watchID; - - return defer.promise; - }, - - clearWatch: function (watchId) { - var defer = $q.defer(); - if (watchId) { - if (this.throwsError) { - defer.reject('Unable to clear watch.'); - } else { - var removed = -1; - for (var i = 0; i < this.watchIntervals.length; i++) { - if (this.watchIntervals[i].watchId === watchId) { - $interval.cancel(watchIntervals[i].interval); - removed = i; - break; - } - } - - if (removed !== -1) { - this.watchIntervals.splice(removed, 1); - } - } - } else { - defer.reject('Unable to clear watch. No watch ID provided.'); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaDialogs - * - * @description - * A service for testing dialogs - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaDialogs', ['$q', function ($q) { - var dialogText = false; - var dialogTitle = ''; - var defaultValue = ''; - var promptResponse = ''; - var beepCount = 0; - var useHostAbilities = true; - - return { - /** - @ngdoc property - @name dialogText - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - The main content in the dialog. - This property should only be used in automated tests. - */ - dialogText: dialogText, - - /** - @ngdoc property - @name dialogTitle - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - The title of the dialog. - This property should only be used in automated tests. - */ - dialogTitle: dialogTitle, - - /** - @ngdoc property - @name defaultValue - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - The default value to be used in a prompt. - This property should only be used in automated tests. - */ - defaultValue: defaultValue, - - /** - @ngdoc property - @name promptResponse - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - Used to simulate a user's response to a prompt. - This property should only be used in automated tests. - */ - promptResponse: promptResponse, - - /** - @ngdoc property - @name buttonLabels - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - An array of the text of each button in the dialog. - This property should only be used in automated tests. - */ - buttonLabels: [], - - /** - @ngdoc property - @name beepCount - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - The number of times a beep has occurred. - This property should only be used in automated tests. - */ - beepCount: beepCount, - - /** - @ngdoc property - @name useHostAbilities - @propertyOf ngCordovaMocks.cordovaDialogs - - @description - A flag that signals whether or not to try and use the host's - (browser or otherwise) prompting capabilities. - This property should only be used in automated tests. - */ - useHostAbilities: useHostAbilities, - - alert: function (message, title, buttonName) { - var d = $q.defer(); - - if (this.useHostAbilities) { - // NOTE: The window.alert method doesn't support a title or callbacks. - alert(message); - d.resolve(); - } else { - this.dialogText = message; - this.dialogTitle = title; - this.buttonLabels.push(buttonName); - d.resolve(); - } - - return d.promise; - }, - - confirm: function (message, title, buttonName) { - var d = $q.defer(); - - if (this.useHostAbilities) { - // NOTE: The window.confirm method doesn't support a title or custom button naming. - var result = confirm(message); - d.resolve(result ? 2 : 1); - } else { - this.dialogText = message; - this.dialogTitle = title; - this.buttonLabels.push(buttonName); - d.resolve(0); - } - - return d.promise; - }, - - prompt: function (message, title, buttonLabels, defaultText) { - var d = $q.defer(); - - if (this.useHostAbilities) { - // NOTE: The window.prompt method doesn't support a title or custom button naming. - var result = prompt(message, defaultText); - d.resolve(result); - } else { - this.dialogText = message; - this.dialogTitle = title; - this.defaultValue = defaultText; - - for (var i = 0; i < buttonLabels.length; i++) { - this.buttonLabels.push(buttonLabels[i]); - } - - d.resolve(this.promptResponse); - } - - return d.promise; - }, - - beep: function (times) { - this.beepCount = times; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaFacebook - * - * @description - * A service for testing Facebook features - * in an app built with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaFacebook', ['$q', function ($q) { - return { - - /** - * These properties are here for the purpose of automated testing only. - **/ - loginShouldSucceedWith: null, - showDialogShouldSucceedWith: null, - apiShouldSucceedWith: null, - getAccessTokenShouldSucceedWith: null, - getLoginStatusShouldSucceedWith: null, - logoutShouldSuceedWith: null, - - login: function (permissions) { - if (this.loginShouldSucceedWith !== null) { - return $q.when(this.loginShouldSucceedWith); - } else { - return $q.reject(); - } - }, - - showDialog: function (options) { - if (this.showDialogShouldSucceedWith !== null) { - return $q.when(this.showDialogShouldSucceedWith); - } else { - return $q.reject(); - } - }, - - api: function (path, permissions) { - if (this.apiShouldSucceedWith !== null) { - return $q.when(this.apiShouldSucceedWith); - } else { - return $q.reject(); - } - }, - - getAccessToken: function () { - if (this.getAccessTokenShouldSucceedWith !== null) { - return $q.when(this.getAccessTokenShouldSucceedWith); - } else { - return $q.reject(); - } - }, - - getLoginStatus: function () { - if (this.getLoginStatusShouldSucceedWith !== null) { - return $q.when(this.getLoginStatusShouldSucceedWith); - } else { - return $q.reject(); - } - }, - - logout: function () { - if (this.logoutShouldSuceedWith !== null) { - return $q.when(this.logoutShouldSuceedWith); - } else { - return $q.reject(); - } - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaFile - * - * @description - * A service for testing interaction with device directories and files - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaFile', ['$q', function ($q) { - var throwsError = false; - var fileSystem = {}; - var shouldMockFiles = false; - var files = {}; - - var mockIt = function (errorMessage) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject(errorMessage); - } else { - defer.resolve(); - } - - return defer.promise; - }; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaFile - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name fileSystem - * @propertyOf ngCordovaMocks.cordovaFile - * - * @description - * A fake, in-memory file system. This is incomplete at this time. - * This property should only be used in automated tests. - **/ - fileSystem: fileSystem, - - /** - * @ngdoc property - * @name shouldMockFiles - * @propertyOf ngCordovaMocks.cordovaFile - * - * @description - * A flag that signals whether one wish to mock files. - * This is useful if you need mocks specific file scenarios. - * This property should only be used in automated tests. - **/ - shouldMockFiles: shouldMockFiles, - - /** - * @ngdoc property - * @name files - * @propertyOf ngCordovaMocks.cordovaFile - * - * @description - * An object that may be used for mocking files on the device. - * This property should only be used in automated tests. - * - * **/ - files: files, - - checkDir: function (directory) { - if (this.shouldMockFiles) { - var defer = $q.defer(); - if (this.files[directory] && !this.files[directory].isFile) { - defer.resolve(); - } else { - defer.reject(); - } - - return defer.promise; - } - - return mockIt.call(this, 'There was an error checking the directory.'); - }, - - createDir: function (directory, overwrite) { - if (this.shouldMockFiles) { - var defer = $q.defer(); - this.files[directory] = {isFile: false}; - defer.resolve(); - return defer.promise; - } - - return mockIt.call(this, 'There was an error creating the directory.'); - }, - - listDir: function (filePath) { - return mockIt.call(this, 'There was an error listing the directory'); - }, - - checkFile: function (filePath) { - if (this.shouldMockFiles) { - var defer = $q.defer(); - if (this.files[filePath] && this.files[filePath].isFile) { - defer.resolve(); - } else { - defer.reject(); - } - - return defer.promise; - } - - return mockIt.call(this, 'There was an error checking for the file.'); - }, - - createFile: function (filePath, overwrite) { - if (this.shouldMockFiles) { - var defer = $q.defer(); - this.files[filePath] = { - isFile: true, - fileContent: '' - }; - defer.resolve(); - return defer.promise; - } - - return mockIt.call(this, 'There was an error creating the file.'); - }, - - removeFile: function (directory, file) { - return mockIt.call(this, 'There was an error removng the file.'); - }, - - writeFile: function (filePath, data, options) { - if (this.shouldMockFiles && filePath && data) { - this.files[filePath] = { - isFile: true, - fileContent: data - }; - } - - return mockIt.call(this, 'There was an error writing the file.'); - }, - - readFile: function (filePath) { - return this.readAsText(filePath); - }, - - readAsText: function (filePath) { - if (this.shouldMockFiles) { - var defer = $q.defer(); - if (files[filePath] && files[filePath].isFile) { - defer.resolve(files[filePath].fileContent); - } else { - defer.reject(); - } - - return defer.promise; - } - - return mockIt.call(this, 'There was an error reading the file as text.'); - }, - - readAsDataURL: function (filePath) { - return mockIt.call(this, 'There was an error reading the file as a data url.'); - }, - - readAsBinaryString: function (filePath) { - return mockIt.call(this, 'There was an error reading the file as a binary string.'); - }, - - readAsArrayBuffer: function (filePath) { - return mockIt.call(this, 'There was an error reading the file as an array buffer.'); - }, - - readFileMetadata: function (filePath) { - return mockIt.call(this, 'There was an error reading the file metadata'); - }, - - readFileAbsolute: function (filePath) { - return mockIt.call(this, 'There was an error reading the file from the absolute path'); - }, - - readFileMetadataAbsolute: function (filePath) { - return mockIt.call(this, 'There was an error reading the file metadta from the absolute path'); - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaFileOpener2 - * - * @description - * A service for testing fileOpener2 - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaFileOpener2', ['$q', function ($q) { - - var throwsError = false; - - return { - - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaFileOpener2 - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - open: function (file, type) { - - var defer = $q.defer(); - - if (this.throwError) { - defer.reject({ - status: 0, - message: 'There was an error capturing the file.' - }); - } else { - defer.resolve(); - } - - return defer.promise; - - }, - - uninstall: function (pack) { - - var defer = $q.defer(); - - if (this.throwError) { - defer.reject({ - status: 0, - message: 'There was an error capturing the packageId.' - }); - } else { - defer.resolve(); - } - - return defer.promise; - - }, - - appIsInstalled: function (pack) { - - var defer = $q.defer(); - - if (this.throwError) { - defer.reject({ - status: 0, - message: 'There was an error capturing the packageId.' - }); - } else { - defer.resolve(); - } - - return defer.promise; - - } - - }; - -}]); - - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaFileTransfer - * - * @description - * A service for testing download and upload - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaFileTransfer', ['$q', function ($q) { - var throwsError = false; - - var mockIt = function (errorMessage) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject(errorMessage); - } else { - defer.resolve(); - } - return defer.promise; - }; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaFileTransfer - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - download: function (source, filePath, options, trust) { - return mockIt.call(this, 'There was an error downloading the file.'); - }, - - upload: function (server, filePath, options) { - return mockIt.call(this, 'There was an error uploading the file.'); - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaGeolocation - * - * @description - * A service for testing location services - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaGeolocation', ['$interval', '$q', function ($interval, $q) { - var throwsError = false; - var useHostAbilities = true; - - var watchIntervals = []; - var locations = []; - var currentPosition = null; - var nextPosition = null; - - return { - /** - @ngdoc property - @name throwsError - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - A flag that signals whether a promise should be rejected or not. - This property should only be used in automated tests. - */ - throwsError: throwsError, - - /** - @ngdoc property - @name watchIntervals - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - The collection of watchers that are currently active. - This property should only be used in automated tests. - */ - watchIntervals: watchIntervals, - - /** - @ngdoc property - @name locations - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - The collection of 'locations' that have been logged. - This property should only be used in automated tests. - */ - locations: locations, - - /** - @ngdoc property - @name currentPosition - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - The last location logged. - This property should only be used in automated tests. - */ - currentPosition: currentPosition, - - /** - @ngdoc property - @name nextPosition - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - The position to be logged the next time that a watcher - gets the location. - This property should only be used in automated tests. - */ - nextPosition: nextPosition, - - /** - @ngdoc property - @name useHostAbilities - @propertyOf ngCordovaMocks.cordovaGeolocation - - @description - A flag that signals whether or not to try and use the host's - (browser or otherwise) geolocation capabilities. - This property should only be used in automated tests. - */ - useHostAbilities: useHostAbilities, - - getCurrentPosition: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the location.'); - } else { - if (options) { - options = options; // This is just to get by JSHint. - } - - if (this.useHostAbilities) { - if (navigator.geolocation) { - navigator.geolocation.getCurrentPosition( - function (position) { - this.currentPosition = position; - defer.resolve(this.currentPosition); - }, - function (error) { - defer.reject(error); - } - ); - } else { - defer.reject('Geolocation is not supported by this browser.'); - } - } else { - defer.resolve(this.currentPosition); - } - } - - return defer.promise; - }, - - watchPosition: function (options) { - var defer = $q.defer(); - var watchID = Math.floor((Math.random() * 1000000) + 1); - var self = this; - - self.locations = []; - - if (self.throwsError) { - defer.reject('There was an error getting the geolocation.'); - } else { - var delay = 1000; - if (options && options.timeout) { - delay = options.timeout; - } - - self.watchIntervals.push({ - watchID: watchID, - interval: $interval( - function () { - if (self.throwsError) { - defer.reject('There was an error watching the geolocation.'); - } - - // Attempt to use nextPosition. - var result = self.nextPosition; - if (result === null) { - // Determine whether to use the host's geolocation capabilities or not - if (self.useHostAbilities) { - if (navigator.geolocation) { - navigator.geolocation.getCurrentPosition( - function (position) { - self.currentPosition = position; - self.locations.push(position); - defer.resolve(position); - }, - function (error) { - defer.reject(error); - } - ); - } else { - defer.reject('Geolocation is not supported by this browser.'); - } - } else { - result = { - coords: { - latitude: ((Math.random() * 180) + 1) - 90, - longitude: ((Math.random() * 360) + 1) - 180, - altitude: ((Math.random() * 100) + 1), - - accuracy: ((Math.random() * 10) + 1), - altitudeAccuracy: ((Math.random() * 10) + 1), - heading: ((Math.random() * 360) + 1), - speed: ((Math.random() * 100) + 1) - }, - timestamp: Date.now() - }; - - self.currentPosition = result; - self.locations.push(result); - defer.notify(result); - } - } - }, - delay - ) - }); - } - - var cancel = function (id) { - var removed = -1; - for (var i = 0; i < self.watchIntervals.length; i++) { - if (self.watchIntervals[i].watchID === id) { - $interval.cancel(watchIntervals[i].interval); - removed = i; - break; - } - } - - if (removed !== -1) { - self.watchIntervals.splice(removed, 1); - } - }; - - defer.promise.cancel = function () { - cancel(watchID); - }; - - defer.promise.clearWatch = function (id) { - cancel(id || watchID); - }; - - defer.promise.watchID = watchID; - - return defer.promise; - }, - - clearWatch: function (watchID) { - var defer = $q.defer(); - if (watchID) { - if (this.throwsError) { - defer.reject('Unable to clear watch.'); - } else { - var removed = -1; - for (var i = 0; i < this.watchIntervals.length; i++) { - if (this.watchIntervals[i].watchID === watchID) { - $interval.cancel(watchIntervals[i].interval); - removed = i; - break; - } - } - - if (removed !== -1) { - this.watchIntervals.splice(removed, 1); - } - } - } else { - defer.reject('Unable to clear watch. No watch ID provided.'); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaGlobalization - * - * @description - * A service for testing features related to a user's locale and timezone. - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaGlobalization', ['$q', function ($q) { - var throwsError = false; - var language = (navigator.language) ? navigator.language : 'en-US'; - var preferredLanguage = {value: language}; - var firstDayOfWeek = 'Sunday'; - var localeName = {value: language}; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaGlobalization - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name preferredLanguage - * @propertyOf ngCordovaMocks.cordovaGlobalization - * - * @description - * The user's preferred language. - * This property should only be used in automated tests. - **/ - preferredLanguage: preferredLanguage, - - /** - * @ngdoc property - * @name localeName - * @propertyOf ngCordovaMocks.cordovaGlobalization - * - * @description - * The name of the user's locale. - * This property should only be used in automated tests. - **/ - localeName: localeName, - - /** - * @ngdoc property - * @name firstDayOfWeek - * @propertyOf ngCordovaMocks.cordovaGlobalization - * - * @description - * The first day of the week based on the user's locale. - * This property should only be used in automated tests. - **/ - firstDayOfWeek: firstDayOfWeek, - - getPreferredLanguage: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the preferred language.'); - } else { - defer.resolve(this.preferredLanguage); - } - - return defer.promise; - }, - - getLocaleName: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the locale name.'); - } else { - defer.resolve(this.localeName); - } - - return defer.promise; - }, - - getFirstDayOfWeek: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the first day of week.'); - } else { - defer.resolve(this.firstDayOfWeek); - } - - return defer.promise; - }, - - dateToString: function (date, options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the string from the date.'); - } else { - var result = ''; - - // TODO: Review - date = date; - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - stringToDate: function (dateString, options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the date from the string.'); - } else { - var result = ''; - - // TODO: Review - dateString = dateString; - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - getDatePattern: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the date pattern.'); - } else { - var result = ''; - - // TODO: Review - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - getDateNames: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting the date names.'); - } else { - var result = ''; - - // TODO: Review - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - isDayLightSavingsTime: function (date) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error getting if this is in daylight savings time mode.'); - } else { - var result = ''; - - // TODO: Review - date = date; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - numberToString: function (number, options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error convertng the number to a string.'); - } else { - var result = ''; - - // TODO: Review - number = number; - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - stringToNumber: function (numberString, options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error convertng the string to a number.'); - } else { - var result = ''; - - // TODO: Review - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - getNumberPattern: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error convertng the string to a number.'); - } else { - var result = ''; - - // TODO: Review - options = options; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - }, - - getCurrencyPattern: function (currencyCode) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error convertng the string to a number.'); - } else { - var result = ''; - - // TODO: Review - currencyCode = currencyCode; - - // END TODO: Review - - defer.resolve(result); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaGoogleAnalytics - * - * @description - * A service for testing google analytics services - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaGoogleAnalytics', ['$q', function ($q) { - var throwsError = false; - var methods = {}; - - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaGeolocation - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - methods.throwsError = throwsError; - - var methodsName = [ - 'startTrackerWithId', - 'setUserId', - 'debugMode', - 'trackView', - 'addCustomDimension', - 'trackEvent', - 'trackException', - 'trackTiming', - 'addTransaction', - 'addTransactionItem' - ]; - - methodsName.forEach(function (funcName) { - methods[funcName] = function () { - var defer = $q.defer(); - - (this.throwsError) ? - defer.reject() : - defer.resolve(); - - return defer.promise; - }; - }); - - return methods; -}]); - -'use strict'; - -/** - * @ngdoc service - * @name ngCordovaMocks.googlePlayGame - * - * @description - * A service for testing Google Play Game features - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaGooglePlayGame', ['$q', function ($q) { - var throwsError = false; - var isSignedIn = false; - var displayName = ''; - - return { - - /** - * @ngdoc property - * @name _throwsError - * @propertyOf ngCordovaMocks.googlePlayGame - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - _throwsError: throwsError, - - /** - * @ngdoc property - * @name _isSignedIn - * @propertyOf ngCordovaMocks.googlePlayGame - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - _isSignedIn: isSignedIn, - - /** - * @ngdoc property - * @name _displayName - * @propertyOf ngCordovaMocks.googlePlayGame - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - _displayName: displayName, - - auth: function () { - var defer = $q.defer(); - if (this._throwsError) { - defer.reject('There was a auth error.'); - } else { - this.isSignedIn = true; - defer.resolve('SIGN IN SUCCESS'); - } - - return defer.promise; - }, - signout: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a signout error.'); - } else { - defer.resolve(); - } - - return defer.promise; - }, - isSignedIn: function () { - var defer = $q.defer(); - if (this._throwsError) { - defer.reject('There was a isSignedIn error.'); - } else { - defer.resolve({ - 'isSignedIn': this._isSignedIn - }); - } - - return defer.promise; - }, - showPlayer: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a showPlayer error.'); - } else { - defer.resolve({ - 'displayName': this._displayName - }); - } - - return defer.promise; - }, - submitScore: function (data) { - var defer = $q.defer(); - if (this._throwsError) { - defer.reject('There was a submitScore error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - }, - showAllLeaderboards: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a showAllLeaderboards error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - }, - showLeaderboard: function (data) { - var defer = $q.defer(); - if (this._throwsError) { - defer.reject('There was a showLeaderboard error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - }, - unlockAchievement: function (data) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a unlockAchievement error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - }, - incrementAchievement: function (data) { - var defer = $q.defer(); - if (this._throwsError) { - defer.reject('There was a incrementAchievement error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - }, - showAchievements: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a showAchievements error.'); - } else { - defer.resolve('OK'); - } - - return defer.promise; - } - }; - -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaKeyboard - * - * @description - * A service for testing device keyboard features - * in an app build with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaKeyboard', function () { - var isVisible = false; - - return { - hideAccessoryBar: function (bool) { - }, - - close: function () { - isVisible = false; - }, - - show: function () { - isVisible = true; - }, - - disableScroll: function (bool) { - }, - - isVisible: function () { - return isVisible; - } - - }; -}); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaKeychain - * - * @description - * A service for testing Keychain features - * in an app built with ngCordova. - **/ -ngCordovaMocks.factory('$cordovaKeychain', ['$q', function ($q) { - var keychains = {}; - - return { - /** - * @ngdoc property - * @name keychains - * @propertyOf ngCordovaMocks.cordovaKeychain - * - * @description - * The collection of 'keychains' that have been saved. - * This property should only be used in automated tests. - **/ - keychains: keychains, - - getForKey: function (key, serviceName) { - var defer = $q.defer(); - - if (this.keychains[serviceName]) { - defer.resolve(this.keychains[serviceName][key]); - } else { - defer.reject(); - } - - return defer.promise; - }, - - setForKey: function (key, serviceName, value) { - var defer = $q.defer(); - - if (!this.keychains[serviceName]) { - this.keychains[serviceName] = {}; - } - - this.keychains[serviceName][key] = value; - - defer.resolve(); - - return defer.promise; - }, - - removeForKey: function (key, serviceName) { - var defer = $q.defer(); - - if (this.keychains[serviceName]) { - delete this.keychains[serviceName][key]; - } - - defer.resolve(); - - return defer.promise; - } - }; -}]); - - -/** - * @ngdoc service - * @name ngCordovaMocks.localNotification - * - * @description - * A service for testing LocalNotificatio - * in an app build with ngCordovaMocks. - */ - -ngCordovaMocks.factory('$cordovaLocalNotification', ['$q', function ($q) { - - var storageKeyPfx = "ngCordLocNotif-"; - - function pfxId(id) { - return storageKeyPfx + id; - } - - function getAllIds(){ - var defer = $q.defer(); - var locNotifIds = []; - for ( var i = 0, len = localStorage.length; i < len; ++i ) { - if (localStorage.key( i ).indexOf(storageKeyPfx) > -1) - locNotifIds.push(parseInt(localStorage.key( i ).split("-")[1])); - } - defer.resolve(locNotifIds); - return defer.promise; - } - - - return { - cancel: function (ids) { - var defer = $q.defer(); - if (typeof(ids) == "number") ids = [ids]; - ids.forEach(function (id){ - localStorage.removeItem([pfxId(id)]); - }); - defer.resolve(); - return defer.promise; - }, - cancelAll: function () { - var defer = $q.defer(); - // TODO - defer.resolve(); - return defer.promise; - }, - clear: function (ids) { - if (typeof(ids) == "number") ids = [ids]; - var defer = $q.defer(); - ids.forEach(function (id){ - localStorage.removeItem([pfxId(id)]); - }); - defer.resolve(); - return defer.promise; - }, - clearAll: function () { - var defer = $q.defer(); - // TODO - // defer.resolve(); - return defer.promise; - }, - isScheduled: function (id){ - var defer = $q.defer(); - if (localStorage[pfxId(id)]) { - defer.resolve(true); - } else { - defer.resolve(false); - } - return defer.promise; - }, - isPresent: function (id){ - var defer = $q.defer(); - if (localStorage[pfxId(id)]) { - defer.resolve(true); - } else { - defer.resolve(false); - } - return defer.promise; - }, - isTriggered: function (id){ - var defer = $q.defer(); - if (localStorage[pfxId(id)]) { - defer.resolve(false); - } else { - defer.resolve(true); - } - return defer.promise; - }, - getAllIds: function () { - return getAllIds(); - }, - getIds: function () { - return getAllIds(); - }, - getScheduledIds: function () { - return getAllIds(); - }, - getTriggeredIds: function () { - var defer = $q.defer(); - defer.resolve([]); - return defer.promise; - }, - hasPermission: function (id){ - var defer = $q.defer(); - defer.resolve(true); - return defer.promise; - }, - schedule: function (data){ - var defer = $q.defer(); - var id = pfxId(data.id); - localStorage[id] = JSON.stringify(data); - defer.resolve(); - return defer.promise; - }, - update: function (data){ - var defer = $q.defer(); - var id = pfxId(data.id); - localStorage[id] = JSON.stringify(data); - defer.resolve(); - return defer.promise; - } - }; -}]); -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaNetwork - * - * @description - * A service for testing networked fetures - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaNetwork', ['$rootScope',function ($rootScope) { - var connectionType = 'WiFi connection'; - var isConnected = true; - - return { - /** - * @ngdoc property - * @name connectionType - * @propertyOf ngCordovaMocks.cordovaNetwork - * - * @description - * They type of connection. Values should match those found at - * https://github.com/apache/cordova-plugin-network-information - * This property should only be used in automated tests. - **/ - connectionType: connectionType, - - /** - * @ngdoc property - * @name isConnected - * @propertyOf ngCordovaMocks.cordovaNetwork - * - * @description - * A flag that signals whether the app is connected to a network. - * This property should only be used in automated tests. - **/ - isConnected: isConnected, - - switchToOnline: function (){ - this.isConnected = true; - $rootScope.$broadcast('$cordovaNetwork:online'); - }, - - switchToOffline: function (){ - this.isConnected = false; - $rootScope.$broadcast('$cordovaNetwork:offline'); - }, - - getNetwork: function () { - return this.connectionType; - }, - - isOnline: function () { - return this.isConnected; - }, - - isOffline: function () { - return !this.isConnected; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaProgress - * - * @description - * A service for testing Progress Indicator - * in an app build with ngCordova. - */ - -ngCordovaMocks.factory('$cordovaProgress', [ - '$timeout', function ($timeout) { - - return { - show: function (_message) { - var message = _message || 'Please wait...'; - console.info('$cordovaProgress.message', message); - }, - - showSimple: function (_dim) { - var dim = _dim || false; - console.info('$cordovaProgress.dim', dim); - }, - - showSimpleWithLabel: function (_dim, _label) { - var dim = _dim || false; - var label = _label || 'Loading...'; - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.label', label); - console.groupEnd(); - }, - - showSimpleWithLabelDetail: function (_dim, _label, _detail) { - var dim = _dim || false; - var label = _label || 'Loading...'; - var detail = _detail || 'Please wait'; - - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.label', label); - console.info('$cordovaProgress.detail', detail); - console.groupEnd(); - }, - - showDeterminate: function (_dim, _timeout) { - var dim = _dim || false; - var timeout = _timeout || 50000; - console.group(); - console.info('$cordovaProgress.dim show', dim); - console.info('$cordovaProgress.timeout', timeout); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress.dim timeout', dim); - }, timeout); - }, - - showDeterminateWithLabel: function (_dim, _timeout, _label) { - var dim = _dim || false; - var timeout = _timeout || 50000; - var label = _label || 'Loading...'; - - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.timeout', timeout); - console.info('$cordovaProgress.label', label); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress[dim, label] timeout', [dim, label]); - }, timeout); - }, - - showAnnular: function (_dim, _timeout) { - var dim = _dim || false; - var timeout = _timeout || 50000; - - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.timeout', timeout); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress.dim timeout', dim); - }, timeout); - }, - - showAnnularWithLabel: function (_dim, _timeout, _label) { - var dim = _dim || false; - var timeout = _timeout || 50000; - var label = _label || 'Loading...'; - - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.timeout', timeout); - console.info('$cordovaProgress.label', label); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress[dim, label] timeout', [dim, label]); - }, timeout); - }, - - showBar: function (_dim, _timeout) { - var dim = _dim || false; - var timeout = _timeout || 50000; - - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.timeout', timeout); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress.dim timeout', dim); - }, timeout); - }, - - showBarWithLabel: function (_dim, _timeout, _label) { - var dim = _dim || false; - var timeout = _timeout || 50000; - var label = _label || 'Loading...'; - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.label', label); - console.info('$cordovaProgress.timeout', timeout); - console.groupEnd(); - $timeout(function () { - console.info('$cordovaProgress[dim, label] timeout', [dim, label]); - }, timeout); - }, - - showSuccess: function (_dim, _label) { - var dim = _dim || false; - var label = _label || 'Success'; - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.label', label); - console.groupEnd(); - }, - - showText: function (_dim, _text, _position) { - var dim = _dim || false; - var text = _text || 'Warning'; - var position = _position || 'center'; - console.group(); - console.info('$cordovaProgress.dim', dim); - console.info('$cordovaProgress.text', text); - console.info('$cordovaProgress.position', position); - console.groupEnd(); - }, - - hide: function () { - console.info('$cordovaProgress.hide'); - } - }; - } -]); - -'use strict'; - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaPush - * - * @description - * A service for testing push notifications features - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaPush', ['$q', '$timeout', '$rootScope', function ($q, $timeout, $rootScope) { - var throwsError = false; - - var deviceToken = ''; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaPush - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name deviceToken - * @propertyOf ngCordovaMocks.cordovaPush - * - * @description - * Token send when service register device - * This property should only be used in automated tests. - **/ - deviceToken: deviceToken, - - onNotification: function (notification) { - $timeout(function () { - $rootScope.$broadcast('$cordovaPush:notificationReceived', notification); - }); - }, - - register: function (config) { - var _self = this; - var defer = $q.defer(); - if (config !== undefined && config.ecb === undefined) { - config.ecb = this.onNotification; - } - - if (this.throwsError) { - defer.reject('There was a register error.'); - } else { - defer.resolve(this.deviceToken); - if (config && config.ecb) { - config.ecb({ - event: 'registered', - regid: _self.deviceToken - }); - } - } - return defer.promise; - }, - - unregister: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was a register error.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaScreenshot - * - * @description - * A service for test app screenshot - * in an app build with ngCordova. - * - * @example - */ -ngCordovaMocks.factory('$cordovaScreenshot', ['$q', function ($q) { - var throwsError = false; - - var DATA_URI_MOCK = ""; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaScreenshot - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - captureToFile: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error capturing the screenshot.'); - } else { - defer.resolve("path"); - } - - return defer.promise; - }, - - captureToUri: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error capturing the screenshot.'); - } else { - defer.resolve(); - } - - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaSocialSharing - * - * @description - * A service for testing via social services - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaSocialSharing', ['$q', function ($q) { - var throwsError = false; - var message = ''; - var image = ''; - var link = ''; - var number = ''; - - var socialService = ''; - var subject = ''; - var toAddresses = []; - var bccAddresses = []; - var attachments = []; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - /** - * @ngdoc property - * @name message - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * The message to be shared via a social service. - * This property should only be used in automated tests. - **/ - message: message, - - /** - * @ngdoc property - * @name image - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * An image to be shared via a social service. - * This property should only be used in automated tests. - **/ - image: image, - - /** - * @ngdoc property - * @name link - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * A link to be shared via a social service. - * This property should only be used in automated tests. - **/ - link: link, - - /** - * @ngdoc property - * @name number - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * A comma-delimited list of phone numbers to send a social message to. - * This property should only be used in automated tests. - **/ - number: number, - - /** - * @ngdoc property - * @name subject - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * The subject of an email. - * This property should only be used in automated tests. - **/ - subject: subject, - - /** - * @ngdoc property - * @name toAddresses - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * An array of email addresses to send an email to. - * This property should only be used in automated tests. - **/ - toAddresses: toAddresses, - - /** - * @ngdoc property - * @name bccAddresses - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * An array of email addresses to blind carbon-copy an email to. - * This property should only be used in automated tests. - **/ - bccAddresses: bccAddresses, - - /** - * @ngdoc property - * @name socialService - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * The name of a social service to share content through. - * This property should only be used in automated tests. - **/ - socialService: socialService, - - /** - * @ngdoc property - * @name attachments - * @propertyOf ngCordovaMocks.cordovaSocialSharing - * - * @description - * An array of attachments to include with an email to be sent. - * This property should only be used in automated tests. - **/ - attachments: attachments, - - shareViaTwitter: function (message, image, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via Twitter.'); - } else { - this.message = message; - this.image = image; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - shareViaWhatsApp: function (message, image, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via WhatsApp.'); - } else { - this.message = message; - this.image = image; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - shareViaFacebook: function (message, image, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via Facebook.'); - } else { - this.message = message; - this.image = image; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - shareViaSMS: function (message, number) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - this.message = message; - this.number = number; - - defer.resolve(); - } - return defer.promise; - }, - - shareViaEmail: function (message, subject, toArr, bccArr, file) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - // These are added to get by JSHINT for now - this.message = message; - this.subject = subject; - this.toAddresses = toArr; - this.bccAddressesc = bccArr; - this.attachments = file; - - defer.resolve(); - } - return defer.promise; - }, - - canShareViaEmail: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject(false); - } else { - defer.resolve(true); - } - return defer.promise; - }, - - canShareVia: function (via, message, subject, file, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - // These are added to get by JSHINT for now - this.message = message; - this.socialService = via; - this.subject = subject; - this.attachments = file; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - shareVia: function (via, message, subject, file, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - this.socialService = via; - this.message = message; - this.subject = subject; - this.attachments = file; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - share: function (message, subject, file, link) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - this.message = message; - this.subject = subject; - this.attachments = file; - this.link = link; - - defer.resolve(); - } - return defer.promise; - }, - - shareWithOptions: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error sharing via SMS.'); - } else { - this.message = options.message; - this.subject = options.subject; - this.attachments = options.files; - this.link = options.url; - - defer.resolve(); - } - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaSplashscreen - * - * @description - * A service for testing the splash screen - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaSplashscreen', function () { - var isVisible = false; - - return { - /** - * @ngdoc property - * @name isVisible - * @propertyOf ngCordovaMocks.cordovaSplashscreen - * - * @description - * A flag that signals whether the splash screen is visible or not. - * This property should only be used in automated tests. - **/ - isVisible: isVisible, - - hide: function () { - // do nothing. everything happens behind the scenes in this case. - // its a stub that is present for completeness. - this.isVisible = false; - return true; - }, - show: function () { - // do nothing. everything happens behind the scenes in this case. - // its a stub that is present for completeness. - this.isVisible = true; - return true; - } - }; -}); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaSQLite - * - * @description - * A service for testing SQLite - * in an app build with ngCordova. - */ - -ngCordovaMocks.factory('$cordovaSQLite', ['$q', function ($q) { - - return { - /** - * These properties are here for the purpose of automated testing only. - **/ - openDBShouldSucceedWith: null, - executeShouldSucceedWith: null, - insertCollectionShouldSucceedWith: null, - nestedExecuteShouldSucceedWith: null, - deleteDBShouldSucceedWith : null, - - openDB: function (options, background) { - if (this.openDBShouldSucceedWith !== null) { - $q.when(this.openDBShouldSucceedWith) - } else { - $q.reject() - } - }, - execute: function (db, query, binding) { - if (this.executeShouldSucceedWith !== null) { - $q.when(this.executeShouldSucceedWith) - } else { - $q.reject() - } - }, - insertCollection: function (db, query, bindings) { - if (this.insertCollectionShouldSucceedWith !== null) { - $q.when(this.insertCollectionShouldSucceedWith) - } else { - $q.reject() - } - }, - nestedExecute: function (db, query1, query2, binding1, binding2) { - if (this.nestedExecuteShouldSucceedWith !== null) { - $q.when(this.nestedExecuteShouldSucceedWith) - } else { - $q.reject() - } - }, - deleteDB: function (dbName) { - if (this.deleteDBShouldSucceedWith !== null) { - $q.when(this.deleteDBShouldSucceedWith) - } else { - $q.reject() - } - } - } -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaStatusbar - * - * @description - * A service for testing the status bar - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaStatusbar', function () { - var isStatusBarVisible = true; - var canOverlayWebView = true; - - return { - /** - * @ngdoc property - * @name isStatusBarVisible - * @propertyOf ngCordovaMocks.cordovaStatusbar - * - * @description - * A flag that signals whether the status bar is visible or not. - * This property should only be used in automated tests. - **/ - isStatusBarVisible: isStatusBarVisible, - - /** - * @ngdoc property - * @name canOverlayWebView - * @propertyOf ngCordovaMocks.cordovaStatusbar - * - * @description - * A flag that signals whether the status bar can overlay the web view. - * This property should only be used in automated tests. - **/ - canOverlayWebView: canOverlayWebView, - - overlaysWebView: function (bool) { - this.canOverlayWebView = bool; - }, - - style: function (style) { - // TODO: Review - return style; - }, - - styleHex: function (colorHex) { - // TODO: review - return colorHex; - }, - - styleColor: function (color) { - // TODO: review - return color; - }, - - hide: function () { - this.isStatusBarVisible = false; - }, - - show: function () { - this.isStatusBarVisible = true; - }, - - isVisible: function () { - return this.isStatusBarVisible; - } - }; -}); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaToast - * - * @description - * A service for testing toasts - * in an app build with ngCordova. - * - * @example - */ -ngCordovaMocks.factory('$cordovaToast', ['$q', function ($q) { - var throwsError = false; - - return { - /** - * @ngdoc property - * @name throwsError - * @propertyOf ngCordovaMocks.cordovaToast - * - * @description - * A flag that signals whether a promise should be rejected or not. - * This property should only be used in automated tests. - **/ - throwsError: throwsError, - - showShortTop: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showShortCenter: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showShortBottom: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showLongTop: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showLongCenter: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showLongBottom: function (message) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - showWithOptions: function (options) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - show: function (message, duration, position) { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error showing the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - }, - hide: function () { - var defer = $q.defer(); - if (this.throwsError) { - defer.reject('There was an error hiding the toast.'); - } else { - defer.resolve(); - } - return defer.promise; - } - }; -}]); - -/** - * @ngdoc service - * @name ngCordovaMocks.cordovaVibration - * - * @description - * A service for testing vibration - * in an app build with ngCordova. - */ -ngCordovaMocks.factory('$cordovaVibration', ['$timeout', function ($timeout) { - var isVibrating = false; - var vibrateTimer = null; - - return { - /** - * @ngdoc property - * @name vibrateTimer - * @propertyOf ngCordovaMocks.cordovaVibration - * - * @description - * Access to the timer associated with vibration. - * This property should only be used in automated tests. - **/ - vibrateTimer: vibrateTimer, - - /** - * @ngdoc property - * @name isVibrating - * @propertyOf ngCordovaMocks.cordovaVibration - * - * @description - * A flag that signals whether vibration is active. - * This property should only be used in automated tests. - **/ - isVibrating: isVibrating, - - vibrate: function (time) { - if (time > 0) { - this.isVibrating = true; - self = this; - - if (time instanceof Array) { - // TODO: Implement pattern here. - // The following is a temporary timer that just looks at the first value - this.vibrateTimer = $timeout( - function () { - self.isVibrating = false; - self.vibrateTimer = null; - }, - time[0] - ); - } else { - this.vibrateTimer = $timeout( - function () { - self.isVibrating = false; - self.vibrateTimer = null; - }, - time - ); - } - } - }, - - /* jshint ignore:start */ - vibrateWithPattern: function (pattern, repeat) { - // Based on the documentation (https://github.com/apache/cordova-plugin-vibration) - // This method is deprecated. For that reason, this isn't implemented at this time. - }, - /* jshint ignore:end */ - - cancelVibration: function () { - if (this.vibrateTimer !== null) { - if (this.isVibrating === true) { - $timeout.cancel(this.vibrateTimer); - this.isVibrating = false; - } - } - } - }; -}]); - -})(); \ No newline at end of file -- cgit v1.2.3