updated to latest 2.6.0rc1 tagged cordova-js libs
diff --git a/lib/cordova.webos-debug.js b/lib/cordova.webos-debug.js
index 1d99d53..b0a2849 100644
--- a/lib/cordova.webos-debug.js
+++ b/lib/cordova.webos-debug.js
@@ -1,8 +1,8 @@
// Platform: webos
-// commit bbf1562d4934b1331ffb263424b6ae054cedeb71
+// commit 4bbb9b5e9f232cc5f090e5065a0d92086b78628d
-// File generated at :: Thu Mar 21 2013 14:40:07 GMT-0700 (PDT)
+// File generated at :: Wed Mar 27 2013 15:35:48 GMT-0700 (PDT)
/*
Licensed to the Apache Software Foundation (ASF) under one
@@ -33,7 +33,7 @@
try {eval("define(\"cordova/commandProxy\", function(require, exports, module) {\n\n\n// internal map of proxy function\nvar CommandProxyMap = {};\n\nmodule.exports = {\n\n // example: cordova.commandProxy.add(\"Accelerometer\",{getCurrentAcceleration: function(successCallback, errorCallback, options) {...},...);\n add:function(id,proxyObj) {\n console.log(\"adding proxy for \" + id);\n CommandProxyMap[id] = proxyObj;\n return proxyObj;\n },\n\n // cordova.commandProxy.remove(\"Accelerometer\");\n remove:function(id) {\n var proxy = CommandProxyMap[id];\n delete CommandProxyMap[id];\n CommandProxyMap[id] = null;\n return proxy;\n },\n\n get:function(service,action) {\n return ( CommandProxyMap[service] ? CommandProxyMap[service][action] : null );\n }\n};\n});\n\n//@ sourceURL=lib/common/commandProxy.js")} catch(e) {console.log("exception: in lib/common/commandProxy.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/exec\", function(require, exports, module) {\n\n/**\n * Execute a cordova command. It is up to the native side whether this action\n * is synchronous or asynchronous. The native side can return:\n * Synchronous: PluginResult object as a JSON string\n * Asynchrounous: Empty string \"\"\n * If async, the native side will cordova.callbackSuccess or cordova.callbackError,\n * depending upon the result of the action.\n *\n * @param {Function} success The success callback\n * @param {Function} fail The fail callback\n * @param {String} service The name of the service to use\n * @param {String} action Action to be run in cordova\n * @param {String[]} [args] Zero or more arguments to pass to the method\n */\n\nvar plugins = {\n \"Device\": require('cordova/plugin/webos/device'),\n \"NetworkStatus\": require('cordova/plugin/webos/network'),\n \"Compass\": require('cordova/plugin/webos/compass'),\n \"Camera\": require('cordova/plugin/webos/camera'),\n \"Accelerometer\" : require('cordova/plugin/webos/accelerometer'),\n \"Notification\" : require('cordova/plugin/webos/notification'),\n \"Geolocation\": require('cordova/plugin/webos/geolocation')\n};\n\nmodule.exports = function(success, fail, service, action, args) {\n try {\n console.error(\"exec:call plugin:\"+service+\":\"+action);\n plugins[service][action](success, fail, args);\n }\n catch(e) {\n console.error(\"missing exec: \" + service + \".\" + action);\n console.error(args);\n console.error(e);\n console.error(e.stack);\n }\n};\n\n});\n\n//@ sourceURL=lib/webos/exec.js")} catch(e) {console.log("exception: in lib/webos/exec.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/modulemapper\", function(require, exports, module) {\n\nvar builder = require('cordova/builder'),\n moduleMap = define.moduleMap,\n symbolList,\n deprecationMap;\n\nexports.reset = function() {\n symbolList = [];\n deprecationMap = {};\n};\n\nfunction addEntry(strategy, moduleName, symbolPath, opt_deprecationMessage) {\n if (!(moduleName in moduleMap)) {\n throw new Error('Module ' + moduleName + ' does not exist.');\n }\n symbolList.push(strategy, moduleName, symbolPath);\n if (opt_deprecationMessage) {\n deprecationMap[symbolPath] = opt_deprecationMessage;\n }\n}\n\n// Note: Android 2.3 does have Function.bind().\nexports.clobbers = function(moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('c', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nexports.merges = function(moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('m', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nexports.defaults = function(moduleName, symbolPath, opt_deprecationMessage) {\n addEntry('d', moduleName, symbolPath, opt_deprecationMessage);\n};\n\nfunction prepareNamespace(symbolPath, context) {\n if (!symbolPath) {\n return context;\n }\n var parts = symbolPath.split('.');\n var cur = context;\n for (var i = 0, part; part = parts[i]; ++i) {\n cur = cur[part] = cur[part] || {};\n }\n return cur;\n}\n\nexports.mapModules = function(context) {\n var origSymbols = {};\n context.CDV_origSymbols = origSymbols;\n for (var i = 0, len = symbolList.length; i < len; i += 3) {\n var strategy = symbolList[i];\n var moduleName = symbolList[i + 1];\n var symbolPath = symbolList[i + 2];\n var lastDot = symbolPath.lastIndexOf('.');\n var namespace = symbolPath.substr(0, lastDot);\n var lastName = symbolPath.substr(lastDot + 1);\n\n var module = require(moduleName);\n var deprecationMsg = symbolPath in deprecationMap ? 'Access made to deprecated symbol: ' + symbolPath + '. ' + deprecationMsg : null;\n var parentObj = prepareNamespace(namespace, context);\n var target = parentObj[lastName];\n\n if (strategy == 'm' && target) {\n builder.recursiveMerge(target, module);\n } else if ((strategy == 'd' && !target) || (strategy != 'd')) {\n if (!(symbolPath in origSymbols)) {\n origSymbols[symbolPath] = target;\n }\n builder.assignOrWrapInDeprecateGetter(parentObj, lastName, module, deprecationMsg);\n }\n }\n};\n\nexports.getOriginalSymbol = function(context, symbolPath) {\n var origSymbols = context.CDV_origSymbols;\n if (origSymbols && (symbolPath in origSymbols)) {\n return origSymbols[symbolPath];\n }\n var parts = symbolPath.split('.');\n var obj = context;\n for (var i = 0; i < parts.length; ++i) {\n obj = obj && obj[parts[i]];\n }\n return obj;\n};\n\nexports.loadMatchingModules = function(matchingRegExp) {\n for (var k in moduleMap) {\n if (matchingRegExp.exec(k)) {\n require(k);\n }\n }\n};\n\nexports.reset();\n\n\n});\n\n//@ sourceURL=lib/common/modulemapper.js")} catch(e) {console.log("exception: in lib/common/modulemapper.js: " + e);console.log(e.stack);}
-try {eval("define(\"cordova/platform\", function(require, exports, module) {\n\nvar service=require('cordova/plugin/webos/service'),\n cordova = require('cordova');\n\nmodule.exports = {\n id: \"webos\",\n initialize: function() {\n var modulemapper = require('cordova/modulemapper');\n\n modulemapper.loadMatchingModules(/cordova.*\\/symbols$/);\n\n modulemapper.merges('cordova/plugin/webos/service', 'navigator.service');\n modulemapper.merges('cordova/plugin/webos/application', 'navigator.application');\n modulemapper.merges('cordova/plugin/webos/window', 'navigator.window');\n modulemapper.merges('cordova/plugin/webos/orientation', 'navigator.orientation');\n modulemapper.merges('cordova/plugin/webos/keyboard', 'navigator.keyboard');\n\n modulemapper.mapModules(window);\n\n if (window.PalmSystem) {\n window.PalmSystem.stageReady();\n }\n\n // create global Mojo object if it does not exist\n Mojo = window.Mojo || {};\n\n // wait for deviceready before listening and firing document events\n document.addEventListener(\"deviceready\", function () {\n\n // LunaSysMgr calls this when the windows is maximized or opened.\n window.Mojo.stageActivated = function() {\n console.log(\"stageActivated\");\n cordova.fireDocumentEvent(\"resume\");\n };\n // LunaSysMgr calls this when the windows is minimized or closed.\n window.Mojo.stageDeactivated = function() {\n console.log(\"stageDeactivated\");\n cordova.fireDocumentEvent(\"pause\");\n };\n // LunaSysMgr calls this when a KeepAlive app's window is hidden\n window.Mojo.hide = function() {\n console.log(\"hide\");\n };\n // LunaSysMgr calls this when a KeepAlive app's window is shown\n window.Mojo.show = function() {\n console.log(\"show\");\n };\n\n // LunaSysMgr calls this whenever an app is \"launched;\"\n window.Mojo.relaunch = function() {\n // need to return true to tell sysmgr the relaunch succeeded.\n // otherwise, it'll try to focus the app, which will focus the first\n // opened window of an app with multiple windows.\n\n var lp=JSON.parse(PalmSystem.launchParams) || {};\n\n if (lp['palm-command'] && lp['palm-command'] == 'open-app-menu') {\n console.log(\"event:ToggleAppMenu\");\n cordova.fireDocumentEvent(\"menubutton\");\n }\n\n console.log(\"relaunch\");\n return true;\n };\n\n // start to listen for network connection changes\n service.Request('palm://com.palm.connectionmanager', {\n method: 'getstatus',\n parameters: { subscribe: true },\n onSuccess: function (result) {\n console.log(\"subscribe:result:\"+JSON.stringify(result));\n\n if (!result.isInternetConnectionAvailable) {\n if (navigator.onLine) {\n console.log(\"Firing event:offline\");\n cordova.fireDocumentEvent(\"offline\");\n }\n } else {\n console.log(\"Firing event:online\");\n cordova.fireDocumentEvent(\"online\");\n }\n },\n onFailure: function(e) {\n console.error(\"subscribe:error\");\n }\n });\n\n });\n }\n};\n\n});\n\n//@ sourceURL=lib/webos/platform.js")} catch(e) {console.log("exception: in lib/webos/platform.js: " + e);console.log(e.stack);}
+try {eval("define(\"cordova/platform\", function(require, exports, module) {\n\n/*global Mojo:false */\n\nvar service=require('cordova/plugin/webos/service'),\n cordova = require('cordova');\n\nmodule.exports = {\n id: \"webos\",\n initialize: function() {\n var modulemapper = require('cordova/modulemapper');\n\n modulemapper.loadMatchingModules(/cordova.*\\/symbols$/);\n modulemapper.mapModules(window);\n\n if (window.PalmSystem) {\n window.PalmSystem.stageReady();\n }\n\n // create global Mojo object if it does not exist\n Mojo = window.Mojo || {};\n\n // wait for deviceready before listening and firing document events\n document.addEventListener(\"deviceready\", function () {\n\n // LunaSysMgr calls this when the windows is maximized or opened.\n window.Mojo.stageActivated = function() {\n console.log(\"stageActivated\");\n cordova.fireDocumentEvent(\"resume\");\n };\n // LunaSysMgr calls this when the windows is minimized or closed.\n window.Mojo.stageDeactivated = function() {\n console.log(\"stageDeactivated\");\n cordova.fireDocumentEvent(\"pause\");\n };\n // LunaSysMgr calls this when a KeepAlive app's window is hidden\n window.Mojo.hide = function() {\n console.log(\"hide\");\n };\n // LunaSysMgr calls this when a KeepAlive app's window is shown\n window.Mojo.show = function() {\n console.log(\"show\");\n };\n\n // LunaSysMgr calls this whenever an app is \"launched;\"\n window.Mojo.relaunch = function() {\n // need to return true to tell sysmgr the relaunch succeeded.\n // otherwise, it'll try to focus the app, which will focus the first\n // opened window of an app with multiple windows.\n\n var lp=JSON.parse(PalmSystem.launchParams) || {};\n\n if (lp['palm-command'] && lp['palm-command'] == 'open-app-menu') {\n console.log(\"event:ToggleAppMenu\");\n cordova.fireDocumentEvent(\"menubutton\");\n }\n\n console.log(\"relaunch\");\n return true;\n };\n\n // start to listen for network connection changes\n service.Request('palm://com.palm.connectionmanager', {\n method: 'getstatus',\n parameters: { subscribe: true },\n onSuccess: function (result) {\n console.log(\"subscribe:result:\"+JSON.stringify(result));\n\n if (!result.isInternetConnectionAvailable) {\n if (navigator.onLine) {\n console.log(\"Firing event:offline\");\n cordova.fireDocumentEvent(\"offline\");\n }\n } else {\n console.log(\"Firing event:online\");\n cordova.fireDocumentEvent(\"online\");\n }\n },\n onFailure: function(e) {\n console.error(\"subscribe:error\");\n }\n });\n\n });\n },\n merges: {\n navigator: {\n children: {\n service: {\n path: \"cordova/plugin/webos/service\"\n },\n application: {\n path: \"cordova/plugin/webos/application\"\n },\n window: {\n path: \"cordova/plugin/webos/window\"\n },\n orientation: {\n path: \"cordova/plugin/webos/orientation\"\n },\n keyboard: {\n path: \"cordova/plugin/webos/keyboard\"\n }\n }\n }\n }\n};\n\n});\n\n//@ sourceURL=lib/webos/platform.js")} catch(e) {console.log("exception: in lib/webos/platform.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/Acceleration\", function(require, exports, module) {\n\nvar Acceleration = function(x, y, z, timestamp) {\n this.x = x;\n this.y = y;\n this.z = z;\n this.timestamp = timestamp || (new Date()).getTime();\n};\n\nmodule.exports = Acceleration;\n\n});\n\n//@ sourceURL=lib/common/plugin/Acceleration.js")} catch(e) {console.log("exception: in lib/common/plugin/Acceleration.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/Camera\", function(require, exports, module) {\n\nvar argscheck = require('cordova/argscheck'),\n exec = require('cordova/exec'),\n Camera = require('cordova/plugin/CameraConstants'),\n CameraPopoverHandle = require('cordova/plugin/CameraPopoverHandle');\n\nvar cameraExport = {};\n\n// Tack on the Camera Constants to the base camera plugin.\nfor (var key in Camera) {\n cameraExport[key] = Camera[key];\n}\n\n/**\n * Gets a picture from source defined by \"options.sourceType\", and returns the\n * image as defined by the \"options.destinationType\" option.\n\n * The defaults are sourceType=CAMERA and destinationType=FILE_URI.\n *\n * @param {Function} successCallback\n * @param {Function} errorCallback\n * @param {Object} options\n */\ncameraExport.getPicture = function(successCallback, errorCallback, options) {\n argscheck.checkArgs('fFO', 'Camera.getPicture', arguments);\n options = options || {};\n var getValue = argscheck.getValue;\n\n var quality = getValue(options.quality, 50);\n var destinationType = getValue(options.destinationType, Camera.DestinationType.FILE_URI);\n var sourceType = getValue(options.sourceType, Camera.PictureSourceType.CAMERA);\n var targetWidth = getValue(options.targetWidth, -1);\n var targetHeight = getValue(options.targetHeight, -1);\n var encodingType = getValue(options.encodingType, Camera.EncodingType.JPEG);\n var mediaType = getValue(options.mediaType, Camera.MediaType.PICTURE);\n var allowEdit = !!options.allowEdit;\n var correctOrientation = !!options.correctOrientation;\n var saveToPhotoAlbum = !!options.saveToPhotoAlbum;\n var popoverOptions = getValue(options.popoverOptions, null);\n var cameraDirection = getValue(options.cameraDirection, Camera.Direction.BACK);\n\n var args = [quality, destinationType, sourceType, targetWidth, targetHeight, encodingType,\n mediaType, allowEdit, correctOrientation, saveToPhotoAlbum, popoverOptions, cameraDirection];\n\n exec(successCallback, errorCallback, \"Camera\", \"takePicture\", args);\n return new CameraPopoverHandle();\n};\n\ncameraExport.cleanup = function(successCallback, errorCallback) {\n exec(successCallback, errorCallback, \"Camera\", \"cleanup\", []);\n};\n\nmodule.exports = cameraExport;\n\n});\n\n//@ sourceURL=lib/common/plugin/Camera.js")} catch(e) {console.log("exception: in lib/common/plugin/Camera.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/CameraConstants\", function(require, exports, module) {\n\nmodule.exports = {\n DestinationType:{\n DATA_URL: 0, // Return base64 encoded string\n FILE_URI: 1, // Return file uri (content://media/external/images/media/2 for Android)\n NATIVE_URI: 2 // Return native uri (eg. asset-library://... for iOS)\n },\n EncodingType:{\n JPEG: 0, // Return JPEG encoded image\n PNG: 1 // Return PNG encoded image\n },\n MediaType:{\n PICTURE: 0, // allow selection of still pictures only. DEFAULT. Will return format specified via DestinationType\n VIDEO: 1, // allow selection of video only, ONLY RETURNS URL\n ALLMEDIA : 2 // allow selection from all media types\n },\n PictureSourceType:{\n PHOTOLIBRARY : 0, // Choose image from picture library (same as SAVEDPHOTOALBUM for Android)\n CAMERA : 1, // Take picture from camera\n SAVEDPHOTOALBUM : 2 // Choose image from picture library (same as PHOTOLIBRARY for Android)\n },\n PopoverArrowDirection:{\n ARROW_UP : 1, // matches iOS UIPopoverArrowDirection constants to specify arrow location on popover\n ARROW_DOWN : 2,\n ARROW_LEFT : 4,\n ARROW_RIGHT : 8,\n ARROW_ANY : 15\n },\n Direction:{\n BACK: 0,\n FRONT: 1\n }\n};\n\n});\n\n//@ sourceURL=lib/common/plugin/CameraConstants.js")} catch(e) {console.log("exception: in lib/common/plugin/CameraConstants.js: " + e);console.log(e.stack);}
@@ -63,14 +63,14 @@
try {eval("define(\"cordova/plugin/FileError\", function(require, exports, module) {\n\n/**\n * FileError\n */\nfunction FileError(error) {\n this.code = error || null;\n}\n\n// File error codes\n// Found in DOMException\nFileError.NOT_FOUND_ERR = 1;\nFileError.SECURITY_ERR = 2;\nFileError.ABORT_ERR = 3;\n\n// Added by File API specification\nFileError.NOT_READABLE_ERR = 4;\nFileError.ENCODING_ERR = 5;\nFileError.NO_MODIFICATION_ALLOWED_ERR = 6;\nFileError.INVALID_STATE_ERR = 7;\nFileError.SYNTAX_ERR = 8;\nFileError.INVALID_MODIFICATION_ERR = 9;\nFileError.QUOTA_EXCEEDED_ERR = 10;\nFileError.TYPE_MISMATCH_ERR = 11;\nFileError.PATH_EXISTS_ERR = 12;\n\nmodule.exports = FileError;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileError.js")} catch(e) {console.log("exception: in lib/common/plugin/FileError.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/FileReader\", function(require, exports, module) {\n\nvar exec = require('cordova/exec'),\n modulemapper = require('cordova/modulemapper'),\n utils = require('cordova/utils'),\n File = require('cordova/plugin/File'),\n FileError = require('cordova/plugin/FileError'),\n ProgressEvent = require('cordova/plugin/ProgressEvent'),\n origFileReader = modulemapper.getOriginalSymbol(this, 'FileReader');\n\n/**\n * This class reads the mobile device file system.\n *\n * For Android:\n * The root directory is the root of the file system.\n * To read from the SD card, the file name is \"sdcard/my_file.txt\"\n * @constructor\n */\nvar FileReader = function() {\n this._readyState = 0;\n this._error = null;\n this._result = null;\n this._fileName = '';\n this._realReader = origFileReader ? new origFileReader() : {};\n};\n\n// States\nFileReader.EMPTY = 0;\nFileReader.LOADING = 1;\nFileReader.DONE = 2;\n\nutils.defineGetter(FileReader.prototype, 'readyState', function() {\n return this._fileName ? this._readyState : this._realReader.readyState;\n});\n\nutils.defineGetter(FileReader.prototype, 'error', function() {\n return this._fileName ? this._error: this._realReader.error;\n});\n\nutils.defineGetter(FileReader.prototype, 'result', function() {\n return this._fileName ? this._result: this._realReader.result;\n});\n\nfunction defineEvent(eventName) {\n utils.defineGetterSetter(FileReader.prototype, eventName, function() {\n return this._realReader[eventName] || null;\n }, function(value) {\n this._realReader[eventName] = value;\n });\n}\ndefineEvent('onloadstart'); // When the read starts.\ndefineEvent('onprogress'); // While reading (and decoding) file or fileBlob data, and reporting partial file data (progress.loaded/progress.total)\ndefineEvent('onload'); // When the read has successfully completed.\ndefineEvent('onerror'); // When the read has failed (see errors).\ndefineEvent('onloadend'); // When the request has completed (either in success or failure).\ndefineEvent('onabort'); // When the read has been aborted. For instance, by invoking the abort() method.\n\nfunction initRead(reader, file) {\n // Already loading something\n if (reader.readyState == FileReader.LOADING) {\n throw new FileError(FileError.INVALID_STATE_ERR);\n }\n\n reader._result = null;\n reader._error = null;\n reader._readyState = FileReader.LOADING;\n\n if (typeof file == 'string') {\n // Deprecated in Cordova 2.4.\n console.warning('Using a string argument with FileReader.readAs functions is deprecated.');\n reader._fileName = file;\n } else if (typeof file.fullPath == 'string') {\n reader._fileName = file.fullPath;\n } else {\n reader._fileName = '';\n return true;\n }\n\n reader.onloadstart && reader.onloadstart(new ProgressEvent(\"loadstart\", {target:reader}));\n}\n\n/**\n * Abort reading file.\n */\nFileReader.prototype.abort = function() {\n if (origFileReader && !this._fileName) {\n return this._realReader.abort();\n }\n this._result = null;\n\n if (this._readyState == FileReader.DONE || this._readyState == FileReader.EMPTY) {\n return;\n }\n\n this._readyState = FileReader.DONE;\n\n // If abort callback\n if (typeof this.onabort === 'function') {\n this.onabort(new ProgressEvent('abort', {target:this}));\n }\n // If load end callback\n if (typeof this.onloadend === 'function') {\n this.onloadend(new ProgressEvent('loadend', {target:this}));\n }\n};\n\n/**\n * Read text file.\n *\n * @param file {File} File object containing file properties\n * @param encoding [Optional] (see http://www.iana.org/assignments/character-sets)\n */\nFileReader.prototype.readAsText = function(file, encoding) {\n if (initRead(this, file)) {\n return this._realReader.readAsText(file, encoding);\n }\n\n // Default encoding is UTF-8\n var enc = encoding ? encoding : \"UTF-8\";\n var me = this;\n var execArgs = [this._fileName, enc, file.start, file.end];\n\n // Read file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // Save result\n me._result = r;\n\n // If onload callback\n if (typeof me.onload === \"function\") {\n me.onload(new ProgressEvent(\"load\", {target:me}));\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n // null result\n me._result = null;\n\n // Save error\n me._error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n }, \"File\", \"readAsText\", execArgs);\n};\n\n\n/**\n * Read file and return data as a base64 encoded data url.\n * A data url is of the form:\n * data:[<mediatype>][;base64],<data>\n *\n * @param file {File} File object containing file properties\n */\nFileReader.prototype.readAsDataURL = function(file) {\n if (initRead(this, file)) {\n return this._realReader.readAsDataURL(file);\n }\n\n var me = this;\n var execArgs = [this._fileName, file.start, file.end];\n\n // Read file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n // Save result\n me._result = r;\n\n // If onload callback\n if (typeof me.onload === \"function\") {\n me.onload(new ProgressEvent(\"load\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n me._result = null;\n\n // Save error\n me._error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n }, \"File\", \"readAsDataURL\", execArgs);\n};\n\n/**\n * Read file and return data as a binary data.\n *\n * @param file {File} File object containing file properties\n */\nFileReader.prototype.readAsBinaryString = function(file) {\n if (initRead(this, file)) {\n return this._realReader.readAsBinaryString(file);\n }\n\n var me = this;\n var execArgs = [this._fileName, file.start, file.end];\n\n // Read file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n me._result = r;\n\n // If onload callback\n if (typeof me.onload === \"function\") {\n me.onload(new ProgressEvent(\"load\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n me._result = null;\n\n // Save error\n me._error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n }, \"File\", \"readAsBinaryString\", execArgs);\n};\n\n/**\n * Read file and return data as a binary data.\n *\n * @param file {File} File object containing file properties\n */\nFileReader.prototype.readAsArrayBuffer = function(file) {\n if (initRead(this, file)) {\n return this._realReader.readAsArrayBuffer(file);\n }\n\n var me = this;\n var execArgs = [this._fileName, file.start, file.end];\n\n // Read file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n me._result = r;\n\n // If onload callback\n if (typeof me.onload === \"function\") {\n me.onload(new ProgressEvent(\"load\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me._readyState === FileReader.DONE) {\n return;\n }\n\n // DONE state\n me._readyState = FileReader.DONE;\n\n me._result = null;\n\n // Save error\n me._error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {target:me}));\n }\n\n // If onloadend callback\n if (typeof me.onloadend === \"function\") {\n me.onloadend(new ProgressEvent(\"loadend\", {target:me}));\n }\n }, \"File\", \"readAsArrayBuffer\", execArgs);\n};\n\nmodule.exports = FileReader;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileReader.js")} catch(e) {console.log("exception: in lib/common/plugin/FileReader.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/FileSystem\", function(require, exports, module) {\n\nvar DirectoryEntry = require('cordova/plugin/DirectoryEntry');\n\n/**\n * An interface representing a file system\n *\n * @constructor\n * {DOMString} name the unique name of the file system (readonly)\n * {DirectoryEntry} root directory of the file system (readonly)\n */\nvar FileSystem = function(name, root) {\n this.name = name || null;\n if (root) {\n this.root = new DirectoryEntry(root.name, root.fullPath);\n }\n};\n\nmodule.exports = FileSystem;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileSystem.js")} catch(e) {console.log("exception: in lib/common/plugin/FileSystem.js: " + e);console.log(e.stack);}
-try {eval("define(\"cordova/plugin/FileTransfer\", function(require, exports, module) {\n\nvar argscheck = require('cordova/argscheck'),\n exec = require('cordova/exec'),\n FileTransferError = require('cordova/plugin/FileTransferError'),\n ProgressEvent = require('cordova/plugin/ProgressEvent');\n\nfunction newProgressEvent(result) {\n var pe = new ProgressEvent();\n pe.lengthComputable = result.lengthComputable;\n pe.loaded = result.loaded;\n pe.total = result.total;\n return pe;\n}\n\nfunction getBasicAuthHeader(urlString) {\n var header = null;\n\n if (window.btoa) {\n // parse the url using the Location object\n var url = document.createElement('a');\n url.href = urlString;\n\n var credentials = null;\n var protocol = url.protocol + \"//\";\n var origin = protocol + url.host;\n\n // check whether there are the username:password credentials in the url\n if (url.href.indexOf(origin) != 0) { // credentials found\n var atIndex = url.href.indexOf(\"@\");\n credentials = url.href.substring(protocol.length, atIndex);\n }\n\n if (credentials) {\n var authHeader = \"Authorization\";\n var authHeaderValue = \"Basic \" + window.btoa(credentials);\n\n header = {\n name : authHeader,\n value : authHeaderValue\n };\n }\n }\n\n return header;\n}\n\nvar idCounter = 0;\n\n/**\n * FileTransfer uploads a file to a remote server.\n * @constructor\n */\nvar FileTransfer = function() {\n this._id = ++idCounter;\n this.onprogress = null; // optional callback\n};\n\n/**\n* Given an absolute file path, uploads a file on the device to a remote server\n* using a multipart HTTP request.\n* @param filePath {String} Full path of the file on the device\n* @param server {String} URL of the server to receive the file\n* @param successCallback (Function} Callback to be invoked when upload has completed\n* @param errorCallback {Function} Callback to be invoked upon error\n* @param options {FileUploadOptions} Optional parameters such as file name and mimetype\n* @param trustAllHosts {Boolean} Optional trust all hosts (e.g. for self-signed certs), defaults to false\n*/\nFileTransfer.prototype.upload = function(filePath, server, successCallback, errorCallback, options, trustAllHosts) {\n argscheck.checkArgs('ssFFO*', 'FileTransfer.upload', arguments);\n // check for options\n var fileKey = null;\n var fileName = null;\n var mimeType = null;\n var params = null;\n var chunkedMode = true;\n var headers = null;\n\n var basicAuthHeader = getBasicAuthHeader(server);\n if (basicAuthHeader) {\n if (!options) {\n options = new FileUploadOptions();\n }\n if (!options.headers) {\n options.headers = {};\n }\n options.headers[basicAuthHeader.name] = basicAuthHeader.value;\n }\n\n if (options) {\n fileKey = options.fileKey;\n fileName = options.fileName;\n mimeType = options.mimeType;\n headers = options.headers;\n if (options.chunkedMode !== null || typeof options.chunkedMode != \"undefined\") {\n chunkedMode = options.chunkedMode;\n }\n if (options.params) {\n params = options.params;\n }\n else {\n params = {};\n }\n }\n\n var fail = errorCallback && function(e) {\n var error = new FileTransferError(e.code, e.source, e.target, e.http_status, e.body);\n errorCallback(error);\n };\n\n var self = this;\n var win = function(result) {\n if (typeof result.lengthComputable != \"undefined\") {\n if (self.onprogress) {\n self.onprogress(newProgressEvent(result));\n }\n } else {\n successCallback && successCallback(result);\n }\n };\n exec(win, fail, 'FileTransfer', 'upload', [filePath, server, fileKey, fileName, mimeType, params, trustAllHosts, chunkedMode, headers, this._id]);\n};\n\n/**\n * Downloads a file form a given URL and saves it to the specified directory.\n * @param source {String} URL of the server to receive the file\n * @param target {String} Full path of the file on the device\n * @param successCallback (Function} Callback to be invoked when upload has completed\n * @param errorCallback {Function} Callback to be invoked upon error\n * @param trustAllHosts {Boolean} Optional trust all hosts (e.g. for self-signed certs), defaults to false\n * @param options {FileDownloadOptions} Optional parameters such as headers\n */\nFileTransfer.prototype.download = function(source, target, successCallback, errorCallback, trustAllHosts, options) {\n argscheck.checkArgs('ssFF*', 'FileTransfer.download', arguments);\n var self = this;\n\n var basicAuthHeader = getBasicAuthHeader(source);\n if (basicAuthHeader) {\n if (!options) {\n options = {};\n }\n if (!options.headers) {\n options.headers = {};\n }\n options.headers[basicAuthHeader.name] = basicAuthHeader.value;\n }\n\n var headers = null;\n if (options) {\n headers = options.headers || null;\n }\n\n var win = function(result) {\n if (typeof result.lengthComputable != \"undefined\") {\n if (self.onprogress) {\n return self.onprogress(newProgressEvent(result));\n }\n } else if (successCallback) {\n var entry = null;\n if (result.isDirectory) {\n entry = new (require('cordova/plugin/DirectoryEntry'))();\n }\n else if (result.isFile) {\n entry = new (require('cordova/plugin/FileEntry'))();\n }\n entry.isDirectory = result.isDirectory;\n entry.isFile = result.isFile;\n entry.name = result.name;\n entry.fullPath = result.fullPath;\n successCallback(entry);\n }\n };\n\n var fail = errorCallback && function(e) {\n var error = new FileTransferError(e.code, e.source, e.target, e.http_status, e.body);\n errorCallback(error);\n };\n\n exec(win, fail, 'FileTransfer', 'download', [source, target, trustAllHosts, this._id, headers]);\n};\n\n/**\n * Aborts the ongoing file transfer on this object\n * @param successCallback {Function} Callback to be invoked upon success\n * @param errorCallback {Function} Callback to be invoked upon error\n */\nFileTransfer.prototype.abort = function(successCallback, errorCallback) {\n exec(successCallback, errorCallback, 'FileTransfer', 'abort', [this._id]);\n};\n\nmodule.exports = FileTransfer;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileTransfer.js")} catch(e) {console.log("exception: in lib/common/plugin/FileTransfer.js: " + e);console.log(e.stack);}
+try {eval("define(\"cordova/plugin/FileTransfer\", function(require, exports, module) {\n\nvar argscheck = require('cordova/argscheck'),\n exec = require('cordova/exec'),\n FileTransferError = require('cordova/plugin/FileTransferError'),\n ProgressEvent = require('cordova/plugin/ProgressEvent');\n\nfunction newProgressEvent(result) {\n var pe = new ProgressEvent();\n pe.lengthComputable = result.lengthComputable;\n pe.loaded = result.loaded;\n pe.total = result.total;\n return pe;\n}\n\nfunction getBasicAuthHeader(urlString) {\n var header = null;\n\n if (window.btoa) {\n // parse the url using the Location object\n var url = document.createElement('a');\n url.href = urlString;\n\n var credentials = null;\n var protocol = url.protocol + \"//\";\n var origin = protocol + url.host;\n\n // check whether there are the username:password credentials in the url\n if (url.href.indexOf(origin) !== 0) { // credentials found\n var atIndex = url.href.indexOf(\"@\");\n credentials = url.href.substring(protocol.length, atIndex);\n }\n\n if (credentials) {\n var authHeader = \"Authorization\";\n var authHeaderValue = \"Basic \" + window.btoa(credentials);\n\n header = {\n name : authHeader,\n value : authHeaderValue\n };\n }\n }\n\n return header;\n}\n\nvar idCounter = 0;\n\n/**\n * FileTransfer uploads a file to a remote server.\n * @constructor\n */\nvar FileTransfer = function() {\n this._id = ++idCounter;\n this.onprogress = null; // optional callback\n};\n\n/**\n* Given an absolute file path, uploads a file on the device to a remote server\n* using a multipart HTTP request.\n* @param filePath {String} Full path of the file on the device\n* @param server {String} URL of the server to receive the file\n* @param successCallback (Function} Callback to be invoked when upload has completed\n* @param errorCallback {Function} Callback to be invoked upon error\n* @param options {FileUploadOptions} Optional parameters such as file name and mimetype\n* @param trustAllHosts {Boolean} Optional trust all hosts (e.g. for self-signed certs), defaults to false\n*/\nFileTransfer.prototype.upload = function(filePath, server, successCallback, errorCallback, options, trustAllHosts) {\n argscheck.checkArgs('ssFFO*', 'FileTransfer.upload', arguments);\n // check for options\n var fileKey = null;\n var fileName = null;\n var mimeType = null;\n var params = null;\n var chunkedMode = true;\n var headers = null;\n var httpMethod = null;\n var basicAuthHeader = getBasicAuthHeader(server);\n if (basicAuthHeader) {\n options = options || {};\n options.headers = options.headers || {};\n options.headers[basicAuthHeader.name] = basicAuthHeader.value;\n }\n\n if (options) {\n fileKey = options.fileKey;\n fileName = options.fileName;\n mimeType = options.mimeType;\n headers = options.headers;\n httpMethod = options.httpMethod || \"POST\";\n if (httpMethod.toUpperCase() == \"PUT\"){\n httpMethod = \"PUT\";\n } else {\n httpMethod = \"POST\";\n }\n if (options.chunkedMode !== null || typeof options.chunkedMode != \"undefined\") {\n chunkedMode = options.chunkedMode;\n }\n if (options.params) {\n params = options.params;\n }\n else {\n params = {};\n }\n }\n\n var fail = errorCallback && function(e) {\n var error = new FileTransferError(e.code, e.source, e.target, e.http_status, e.body);\n errorCallback(error);\n };\n\n var self = this;\n var win = function(result) {\n if (typeof result.lengthComputable != \"undefined\") {\n if (self.onprogress) {\n self.onprogress(newProgressEvent(result));\n }\n } else {\n successCallback && successCallback(result);\n }\n };\n exec(win, fail, 'FileTransfer', 'upload', [filePath, server, fileKey, fileName, mimeType, params, trustAllHosts, chunkedMode, headers, this._id, httpMethod]);\n};\n\n/**\n * Downloads a file form a given URL and saves it to the specified directory.\n * @param source {String} URL of the server to receive the file\n * @param target {String} Full path of the file on the device\n * @param successCallback (Function} Callback to be invoked when upload has completed\n * @param errorCallback {Function} Callback to be invoked upon error\n * @param trustAllHosts {Boolean} Optional trust all hosts (e.g. for self-signed certs), defaults to false\n * @param options {FileDownloadOptions} Optional parameters such as headers\n */\nFileTransfer.prototype.download = function(source, target, successCallback, errorCallback, trustAllHosts, options) {\n argscheck.checkArgs('ssFF*', 'FileTransfer.download', arguments);\n var self = this;\n\n var basicAuthHeader = getBasicAuthHeader(source);\n if (basicAuthHeader) {\n options = options || {};\n options.headers = options.headers || {};\n options.headers[basicAuthHeader.name] = basicAuthHeader.value;\n }\n\n var headers = null;\n if (options) {\n headers = options.headers || null;\n }\n\n var win = function(result) {\n if (typeof result.lengthComputable != \"undefined\") {\n if (self.onprogress) {\n return self.onprogress(newProgressEvent(result));\n }\n } else if (successCallback) {\n var entry = null;\n if (result.isDirectory) {\n entry = new (require('cordova/plugin/DirectoryEntry'))();\n }\n else if (result.isFile) {\n entry = new (require('cordova/plugin/FileEntry'))();\n }\n entry.isDirectory = result.isDirectory;\n entry.isFile = result.isFile;\n entry.name = result.name;\n entry.fullPath = result.fullPath;\n successCallback(entry);\n }\n };\n\n var fail = errorCallback && function(e) {\n var error = new FileTransferError(e.code, e.source, e.target, e.http_status, e.body);\n errorCallback(error);\n };\n\n exec(win, fail, 'FileTransfer', 'download', [source, target, trustAllHosts, this._id, headers]);\n};\n\n/**\n * Aborts the ongoing file transfer on this object. The original error\n * callback for the file transfer will be called if necessary.\n */\nFileTransfer.prototype.abort = function() {\n exec(null, null, 'FileTransfer', 'abort', [this._id]);\n};\n\nmodule.exports = FileTransfer;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileTransfer.js")} catch(e) {console.log("exception: in lib/common/plugin/FileTransfer.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/FileTransferError\", function(require, exports, module) {\n\n/**\n * FileTransferError\n * @constructor\n */\nvar FileTransferError = function(code, source, target, status, body) {\n this.code = code || null;\n this.source = source || null;\n this.target = target || null;\n this.http_status = status || null;\n this.body = body || null;\n};\n\nFileTransferError.FILE_NOT_FOUND_ERR = 1;\nFileTransferError.INVALID_URL_ERR = 2;\nFileTransferError.CONNECTION_ERR = 3;\nFileTransferError.ABORT_ERR = 4;\n\nmodule.exports = FileTransferError;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileTransferError.js")} catch(e) {console.log("exception: in lib/common/plugin/FileTransferError.js: " + e);console.log(e.stack);}
-try {eval("define(\"cordova/plugin/FileUploadOptions\", function(require, exports, module) {\n\n/**\n * Options to customize the HTTP request used to upload files.\n * @constructor\n * @param fileKey {String} Name of file request parameter.\n * @param fileName {String} Filename to be used by the server. Defaults to image.jpg.\n * @param mimeType {String} Mimetype of the uploaded file. Defaults to image/jpeg.\n * @param params {Object} Object with key: value params to send to the server.\n * @param headers {Object} Keys are header names, values are header values. Multiple\n * headers of the same name are not supported.\n */\nvar FileUploadOptions = function(fileKey, fileName, mimeType, params, headers) {\n this.fileKey = fileKey || null;\n this.fileName = fileName || null;\n this.mimeType = mimeType || null;\n this.params = params || null;\n this.headers = headers || null;\n};\n\nmodule.exports = FileUploadOptions;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileUploadOptions.js")} catch(e) {console.log("exception: in lib/common/plugin/FileUploadOptions.js: " + e);console.log(e.stack);}
+try {eval("define(\"cordova/plugin/FileUploadOptions\", function(require, exports, module) {\n\n/**\n * Options to customize the HTTP request used to upload files.\n * @constructor\n * @param fileKey {String} Name of file request parameter.\n * @param fileName {String} Filename to be used by the server. Defaults to image.jpg.\n * @param mimeType {String} Mimetype of the uploaded file. Defaults to image/jpeg.\n * @param params {Object} Object with key: value params to send to the server.\n * @param headers {Object} Keys are header names, values are header values. Multiple\n * headers of the same name are not supported.\n */\nvar FileUploadOptions = function(fileKey, fileName, mimeType, params, headers, httpMethod) {\n this.fileKey = fileKey || null;\n this.fileName = fileName || null;\n this.mimeType = mimeType || null;\n this.params = params || null;\n this.headers = headers || null;\n this.httpMethod = httpMethod || null;\n};\n\nmodule.exports = FileUploadOptions;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileUploadOptions.js")} catch(e) {console.log("exception: in lib/common/plugin/FileUploadOptions.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/FileUploadResult\", function(require, exports, module) {\n\n/**\n * FileUploadResult\n * @constructor\n */\nvar FileUploadResult = function() {\n this.bytesSent = 0;\n this.responseCode = null;\n this.response = null;\n};\n\nmodule.exports = FileUploadResult;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileUploadResult.js")} catch(e) {console.log("exception: in lib/common/plugin/FileUploadResult.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/FileWriter\", function(require, exports, module) {\n\nvar exec = require('cordova/exec'),\n FileError = require('cordova/plugin/FileError'),\n ProgressEvent = require('cordova/plugin/ProgressEvent');\n\n/**\n * This class writes to the mobile device file system.\n *\n * For Android:\n * The root directory is the root of the file system.\n * To write to the SD card, the file name is \"sdcard/my_file.txt\"\n *\n * @constructor\n * @param file {File} File object containing file properties\n * @param append if true write to the end of the file, otherwise overwrite the file\n */\nvar FileWriter = function(file) {\n this.fileName = \"\";\n this.length = 0;\n if (file) {\n this.fileName = file.fullPath || file;\n this.length = file.size || 0;\n }\n // default is to write at the beginning of the file\n this.position = 0;\n\n this.readyState = 0; // EMPTY\n\n this.result = null;\n\n // Error\n this.error = null;\n\n // Event handlers\n this.onwritestart = null; // When writing starts\n this.onprogress = null; // While writing the file, and reporting partial file data\n this.onwrite = null; // When the write has successfully completed.\n this.onwriteend = null; // When the request has completed (either in success or failure).\n this.onabort = null; // When the write has been aborted. For instance, by invoking the abort() method.\n this.onerror = null; // When the write has failed (see errors).\n};\n\n// States\nFileWriter.INIT = 0;\nFileWriter.WRITING = 1;\nFileWriter.DONE = 2;\n\n/**\n * Abort writing file.\n */\nFileWriter.prototype.abort = function() {\n // check for invalid state\n if (this.readyState === FileWriter.DONE || this.readyState === FileWriter.INIT) {\n throw new FileError(FileError.INVALID_STATE_ERR);\n }\n\n // set error\n this.error = new FileError(FileError.ABORT_ERR);\n\n this.readyState = FileWriter.DONE;\n\n // If abort callback\n if (typeof this.onabort === \"function\") {\n this.onabort(new ProgressEvent(\"abort\", {\"target\":this}));\n }\n\n // If write end callback\n if (typeof this.onwriteend === \"function\") {\n this.onwriteend(new ProgressEvent(\"writeend\", {\"target\":this}));\n }\n};\n\n/**\n * Writes data to the file\n *\n * @param text to be written\n */\nFileWriter.prototype.write = function(text) {\n // Throw an exception if we are already writing a file\n if (this.readyState === FileWriter.WRITING) {\n throw new FileError(FileError.INVALID_STATE_ERR);\n }\n\n // WRITING state\n this.readyState = FileWriter.WRITING;\n\n var me = this;\n\n // If onwritestart callback\n if (typeof me.onwritestart === \"function\") {\n me.onwritestart(new ProgressEvent(\"writestart\", {\"target\":me}));\n }\n\n // Write file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me.readyState === FileWriter.DONE) {\n return;\n }\n\n // position always increases by bytes written because file would be extended\n me.position += r;\n // The length of the file is now where we are done writing.\n\n me.length = me.position;\n\n // DONE state\n me.readyState = FileWriter.DONE;\n\n // If onwrite callback\n if (typeof me.onwrite === \"function\") {\n me.onwrite(new ProgressEvent(\"write\", {\"target\":me}));\n }\n\n // If onwriteend callback\n if (typeof me.onwriteend === \"function\") {\n me.onwriteend(new ProgressEvent(\"writeend\", {\"target\":me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me.readyState === FileWriter.DONE) {\n return;\n }\n\n // DONE state\n me.readyState = FileWriter.DONE;\n\n // Save error\n me.error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {\"target\":me}));\n }\n\n // If onwriteend callback\n if (typeof me.onwriteend === \"function\") {\n me.onwriteend(new ProgressEvent(\"writeend\", {\"target\":me}));\n }\n }, \"File\", \"write\", [this.fileName, text, this.position]);\n};\n\n/**\n * Moves the file pointer to the location specified.\n *\n * If the offset is a negative number the position of the file\n * pointer is rewound. If the offset is greater than the file\n * size the position is set to the end of the file.\n *\n * @param offset is the location to move the file pointer to.\n */\nFileWriter.prototype.seek = function(offset) {\n // Throw an exception if we are already writing a file\n if (this.readyState === FileWriter.WRITING) {\n throw new FileError(FileError.INVALID_STATE_ERR);\n }\n\n if (!offset && offset !== 0) {\n return;\n }\n\n // See back from end of file.\n if (offset < 0) {\n this.position = Math.max(offset + this.length, 0);\n }\n // Offset is bigger than file size so set position\n // to the end of the file.\n else if (offset > this.length) {\n this.position = this.length;\n }\n // Offset is between 0 and file size so set the position\n // to start writing.\n else {\n this.position = offset;\n }\n};\n\n/**\n * Truncates the file to the size specified.\n *\n * @param size to chop the file at.\n */\nFileWriter.prototype.truncate = function(size) {\n // Throw an exception if we are already writing a file\n if (this.readyState === FileWriter.WRITING) {\n throw new FileError(FileError.INVALID_STATE_ERR);\n }\n\n // WRITING state\n this.readyState = FileWriter.WRITING;\n\n var me = this;\n\n // If onwritestart callback\n if (typeof me.onwritestart === \"function\") {\n me.onwritestart(new ProgressEvent(\"writestart\", {\"target\":this}));\n }\n\n // Write file\n exec(\n // Success callback\n function(r) {\n // If DONE (cancelled), then don't do anything\n if (me.readyState === FileWriter.DONE) {\n return;\n }\n\n // DONE state\n me.readyState = FileWriter.DONE;\n\n // Update the length of the file\n me.length = r;\n me.position = Math.min(me.position, r);\n\n // If onwrite callback\n if (typeof me.onwrite === \"function\") {\n me.onwrite(new ProgressEvent(\"write\", {\"target\":me}));\n }\n\n // If onwriteend callback\n if (typeof me.onwriteend === \"function\") {\n me.onwriteend(new ProgressEvent(\"writeend\", {\"target\":me}));\n }\n },\n // Error callback\n function(e) {\n // If DONE (cancelled), then don't do anything\n if (me.readyState === FileWriter.DONE) {\n return;\n }\n\n // DONE state\n me.readyState = FileWriter.DONE;\n\n // Save error\n me.error = new FileError(e);\n\n // If onerror callback\n if (typeof me.onerror === \"function\") {\n me.onerror(new ProgressEvent(\"error\", {\"target\":me}));\n }\n\n // If onwriteend callback\n if (typeof me.onwriteend === \"function\") {\n me.onwriteend(new ProgressEvent(\"writeend\", {\"target\":me}));\n }\n }, \"File\", \"truncate\", [this.fileName, size]);\n};\n\nmodule.exports = FileWriter;\n\n});\n\n//@ sourceURL=lib/common/plugin/FileWriter.js")} catch(e) {console.log("exception: in lib/common/plugin/FileWriter.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/Flags\", function(require, exports, module) {\n\n/**\n * Supplies arguments to methods that lookup or create files and directories.\n *\n * @param create\n * {boolean} file or directory if it doesn't exist\n * @param exclusive\n * {boolean} used with create; if true the command will fail if\n * target path exists\n */\nfunction Flags(create, exclusive) {\n this.create = create || false;\n this.exclusive = exclusive || false;\n}\n\nmodule.exports = Flags;\n\n});\n\n//@ sourceURL=lib/common/plugin/Flags.js")} catch(e) {console.log("exception: in lib/common/plugin/Flags.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/GlobalizationError\", function(require, exports, module) {\n\n\n/**\n * Globalization error object\n *\n * @constructor\n * @param code\n * @param message\n */\nvar GlobalizationError = function(code, message) {\n this.code = code || null;\n this.message = message || '';\n};\n\n// Globalization error codes\nGlobalizationError.UNKNOWN_ERROR = 0;\nGlobalizationError.FORMATTING_ERROR = 1;\nGlobalizationError.PARSING_ERROR = 2;\nGlobalizationError.PATTERN_ERROR = 3;\n\nmodule.exports = GlobalizationError;\n\n});\n\n//@ sourceURL=lib/common/plugin/GlobalizationError.js")} catch(e) {console.log("exception: in lib/common/plugin/GlobalizationError.js: " + e);console.log(e.stack);}
-try {eval("define(\"cordova/plugin/InAppBrowser\", function(require, exports, module) {\n\nvar exec = require('cordova/exec');\nvar channel = require('cordova/channel');\n\nfunction InAppBrowser() {\n this.channels = {\n 'loadstart': channel.create('loadstart'),\n 'loadstop' : channel.create('loadstop'),\n 'loaderror' : channel.create('loaderror'),\n 'exit' : channel.create('exit')\n };\n}\n\nInAppBrowser.prototype = {\n _eventHandler: function (event) {\n if (event.type in this.channels) {\n this.channels[event.type].fire(event);\n }\n },\n close: function (eventname) {\n exec(null, null, \"InAppBrowser\", \"close\", []);\n },\n addEventListener: function (eventname,f) {\n if (eventname in this.channels) {\n this.channels[eventname].subscribe(f);\n }\n },\n removeEventListener: function(eventname, f) {\n if (eventname in this.channels) {\n this.channels[eventname].unsubscribe(f);\n }\n }\n};\n\nmodule.exports = function(strUrl, strWindowName, strWindowFeatures) {\n var iab = new InAppBrowser();\n var cb = function(eventname) {\n iab._eventHandler(eventname);\n };\n exec(cb, cb, \"InAppBrowser\", \"open\", [strUrl, strWindowName, strWindowFeatures]);\n return iab;\n};\n\n\n});\n\n//@ sourceURL=lib/common/plugin/InAppBrowser.js")} catch(e) {console.log("exception: in lib/common/plugin/InAppBrowser.js: " + e);console.log(e.stack);}
+try {eval("define(\"cordova/plugin/InAppBrowser\", function(require, exports, module) {\n\nvar exec = require('cordova/exec');\nvar channel = require('cordova/channel');\n\nfunction InAppBrowser() {\n this.channels = {\n 'loadstart': channel.create('loadstart'),\n 'loadstop' : channel.create('loadstop'),\n 'loaderror' : channel.create('loaderror'),\n 'exit' : channel.create('exit')\n };\n}\n\nInAppBrowser.prototype = {\n _eventHandler: function (event) {\n if (event.type in this.channels) {\n this.channels[event.type].fire(event);\n }\n },\n close: function (eventname) {\n exec(null, null, \"InAppBrowser\", \"close\", []);\n },\n addEventListener: function (eventname,f) {\n if (eventname in this.channels) {\n this.channels[eventname].subscribe(f);\n }\n },\n removeEventListener: function(eventname, f) {\n if (eventname in this.channels) {\n this.channels[eventname].unsubscribe(f);\n }\n },\n executeScript: function(injectDetails, cb) {\n var script,\n sourceString;\n if (injectDetails.code) {\n exec(cb, null, \"InAppBrowser\", \"injectScriptCode\", [injectDetails.code]);\n } else if (injectDetails.file) {\n sourceString = JSON.stringify(injectDetails.file);\n script = \"(function(d) { var c = d.createElement('script'); c.src = \" + sourceString + \"; d.body.appendChild(c); })(document)\";\n exec(cb, null, \"InAppBrowser\", \"injectScriptCode\", [script]);\n } else {\n throw new Error('executeScript requires exactly one of code or file to be specified');\n }\n },\n insertCSS: function(injectDetails, cb) {\n var script,\n sourceString;\n if (injectDetails.code) {\n sourceString = JSON.stringify(injectDetails.code);\n script = \"(function(d) { var c = d.createElement('style'); c.innerHTML = \" + sourceString + \"; d.body.appendChild(c); })(document)\";\n exec(cb, null, \"InAppBrowser\", \"injectScriptCode\", [script]);\n } else if (injectDetails.file) {\n sourceString = JSON.stringify(injectDetails.file);\n script = \"(function(d) { var c = d.createElement('link'); c.rel='stylesheet', c.type='text/css'; c.href = \" + sourceString + \"; d.body.appendChild(c); })(document)\";\n exec(cb, null, \"InAppBrowser\", \"injectScriptCode\", [script]);\n } else {\n throw new Error('insertCSS requires exactly one of code or file to be specified');\n }\n }\n};\n\nmodule.exports = function(strUrl, strWindowName, strWindowFeatures) {\n var iab = new InAppBrowser();\n var cb = function(eventname) {\n iab._eventHandler(eventname);\n };\n exec(cb, cb, \"InAppBrowser\", \"open\", [strUrl, strWindowName, strWindowFeatures]);\n return iab;\n};\n\n\n});\n\n//@ sourceURL=lib/common/plugin/InAppBrowser.js")} catch(e) {console.log("exception: in lib/common/plugin/InAppBrowser.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/LocalFileSystem\", function(require, exports, module) {\n\nvar exec = require('cordova/exec');\n\n/**\n * Represents a local file system.\n */\nvar LocalFileSystem = function() {\n\n};\n\nLocalFileSystem.TEMPORARY = 0; //temporary, with no guarantee of persistence\nLocalFileSystem.PERSISTENT = 1; //persistent\n\nmodule.exports = LocalFileSystem;\n\n});\n\n//@ sourceURL=lib/common/plugin/LocalFileSystem.js")} catch(e) {console.log("exception: in lib/common/plugin/LocalFileSystem.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/Media\", function(require, exports, module) {\n\nvar argscheck = require('cordova/argscheck'),\n utils = require('cordova/utils'),\n exec = require('cordova/exec');\n\nvar mediaObjects = {};\n\n/**\n * This class provides access to the device media, interfaces to both sound and video\n *\n * @constructor\n * @param src The file name or url to play\n * @param successCallback The callback to be called when the file is done playing or recording.\n * successCallback()\n * @param errorCallback The callback to be called if there is an error.\n * errorCallback(int errorCode) - OPTIONAL\n * @param statusCallback The callback to be called when media status has changed.\n * statusCallback(int statusCode) - OPTIONAL\n */\nvar Media = function(src, successCallback, errorCallback, statusCallback) {\n argscheck.checkArgs('SFFF', 'Media', arguments);\n this.id = utils.createUUID();\n mediaObjects[this.id] = this;\n this.src = src;\n this.successCallback = successCallback;\n this.errorCallback = errorCallback;\n this.statusCallback = statusCallback;\n this._duration = -1;\n this._position = -1;\n exec(null, this.errorCallback, \"Media\", \"create\", [this.id, this.src]);\n};\n\n// Media messages\nMedia.MEDIA_STATE = 1;\nMedia.MEDIA_DURATION = 2;\nMedia.MEDIA_POSITION = 3;\nMedia.MEDIA_ERROR = 9;\n\n// Media states\nMedia.MEDIA_NONE = 0;\nMedia.MEDIA_STARTING = 1;\nMedia.MEDIA_RUNNING = 2;\nMedia.MEDIA_PAUSED = 3;\nMedia.MEDIA_STOPPED = 4;\nMedia.MEDIA_MSG = [\"None\", \"Starting\", \"Running\", \"Paused\", \"Stopped\"];\n\n// \"static\" function to return existing objs.\nMedia.get = function(id) {\n return mediaObjects[id];\n};\n\n/**\n * Start or resume playing audio file.\n */\nMedia.prototype.play = function(options) {\n exec(null, null, \"Media\", \"startPlayingAudio\", [this.id, this.src, options]);\n};\n\n/**\n * Stop playing audio file.\n */\nMedia.prototype.stop = function() {\n var me = this;\n exec(function() {\n me._position = 0;\n }, this.errorCallback, \"Media\", \"stopPlayingAudio\", [this.id]);\n};\n\n/**\n * Seek or jump to a new time in the track..\n */\nMedia.prototype.seekTo = function(milliseconds) {\n var me = this;\n exec(function(p) {\n me._position = p;\n }, this.errorCallback, \"Media\", \"seekToAudio\", [this.id, milliseconds]);\n};\n\n/**\n * Pause playing audio file.\n */\nMedia.prototype.pause = function() {\n exec(null, this.errorCallback, \"Media\", \"pausePlayingAudio\", [this.id]);\n};\n\n/**\n * Get duration of an audio file.\n * The duration is only set for audio that is playing, paused or stopped.\n *\n * @return duration or -1 if not known.\n */\nMedia.prototype.getDuration = function() {\n return this._duration;\n};\n\n/**\n * Get position of audio.\n */\nMedia.prototype.getCurrentPosition = function(success, fail) {\n var me = this;\n exec(function(p) {\n me._position = p;\n success(p);\n }, fail, \"Media\", \"getCurrentPositionAudio\", [this.id]);\n};\n\n/**\n * Start recording audio file.\n */\nMedia.prototype.startRecord = function() {\n exec(null, this.errorCallback, \"Media\", \"startRecordingAudio\", [this.id, this.src]);\n};\n\n/**\n * Stop recording audio file.\n */\nMedia.prototype.stopRecord = function() {\n exec(null, this.errorCallback, \"Media\", \"stopRecordingAudio\", [this.id]);\n};\n\n/**\n * Release the resources.\n */\nMedia.prototype.release = function() {\n exec(null, this.errorCallback, \"Media\", \"release\", [this.id]);\n};\n\n/**\n * Adjust the volume.\n */\nMedia.prototype.setVolume = function(volume) {\n exec(null, null, \"Media\", \"setVolume\", [this.id, volume]);\n};\n\n/**\n * Audio has status update.\n * PRIVATE\n *\n * @param id The media object id (string)\n * @param msgType The 'type' of update this is\n * @param value Use of value is determined by the msgType\n */\nMedia.onStatus = function(id, msgType, value) {\n\n var media = mediaObjects[id];\n\n if(media) {\n switch(msgType) {\n case Media.MEDIA_STATE :\n media.statusCallback && media.statusCallback(value);\n if(value == Media.MEDIA_STOPPED) {\n media.successCallback && media.successCallback();\n }\n break;\n case Media.MEDIA_DURATION :\n media._duration = value;\n break;\n case Media.MEDIA_ERROR :\n media.errorCallback && media.errorCallback(value);\n break;\n case Media.MEDIA_POSITION :\n media._position = Number(value);\n break;\n default :\n console.error && console.error(\"Unhandled Media.onStatus :: \" + msgType);\n break;\n }\n }\n else {\n console.error && console.error(\"Received Media.onStatus callback for unknown media :: \" + id);\n }\n\n};\n\nmodule.exports = Media;\n\n});\n\n//@ sourceURL=lib/common/plugin/Media.js")} catch(e) {console.log("exception: in lib/common/plugin/Media.js: " + e);console.log(e.stack);}
try {eval("define(\"cordova/plugin/MediaError\", function(require, exports, module) {\n\n/**\n * This class contains information about any Media errors.\n*/\n/*\n According to :: http://dev.w3.org/html5/spec-author-view/video.html#mediaerror\n We should never be creating these objects, we should just implement the interface\n which has 1 property for an instance, 'code'\n\n instead of doing :\n errorCallbackFunction( new MediaError(3,'msg') );\nwe should simply use a literal :\n errorCallbackFunction( {'code':3} );\n */\n\n var _MediaError = window.MediaError;\n\n\nif(!_MediaError) {\n window.MediaError = _MediaError = function(code, msg) {\n this.code = (typeof code != 'undefined') ? code : null;\n this.message = msg || \"\"; // message is NON-standard! do not use!\n };\n}\n\n_MediaError.MEDIA_ERR_NONE_ACTIVE = _MediaError.MEDIA_ERR_NONE_ACTIVE || 0;\n_MediaError.MEDIA_ERR_ABORTED = _MediaError.MEDIA_ERR_ABORTED || 1;\n_MediaError.MEDIA_ERR_NETWORK = _MediaError.MEDIA_ERR_NETWORK || 2;\n_MediaError.MEDIA_ERR_DECODE = _MediaError.MEDIA_ERR_DECODE || 3;\n_MediaError.MEDIA_ERR_NONE_SUPPORTED = _MediaError.MEDIA_ERR_NONE_SUPPORTED || 4;\n// TODO: MediaError.MEDIA_ERR_NONE_SUPPORTED is legacy, the W3 spec now defines it as below.\n// as defined by http://dev.w3.org/html5/spec-author-view/video.html#error-codes\n_MediaError.MEDIA_ERR_SRC_NOT_SUPPORTED = _MediaError.MEDIA_ERR_SRC_NOT_SUPPORTED || 4;\n\nmodule.exports = _MediaError;\n\n});\n\n//@ sourceURL=lib/common/plugin/MediaError.js")} catch(e) {console.log("exception: in lib/common/plugin/MediaError.js: " + e);console.log(e.stack);}
@@ -135,6 +135,6 @@
try {eval("\n(function (context) {\n // Replace navigator before any modules are required(), to ensure it happens as soon as possible.\n // We replace it so that properties that can't be clobbered can instead be overridden.\n function replaceNavigator(origNavigator) {\n var CordovaNavigator = function() {};\n CordovaNavigator.prototype = origNavigator;\n var newNavigator = new CordovaNavigator();\n // This work-around really only applies to new APIs that are newer than Function.bind.\n // Without it, APIs such as getGamepads() break.\n if (CordovaNavigator.bind) {\n for (var key in origNavigator) {\n if (typeof origNavigator[key] == 'function') {\n newNavigator[key] = origNavigator[key].bind(origNavigator);\n }\n }\n }\n return newNavigator;\n }\n if (context.navigator) {\n context.navigator = replaceNavigator(context.navigator);\n }\n\n var channel = require(\"cordova/channel\");\n\n // _nativeReady is global variable that the native side can set\n // to signify that the native code is ready. It is a global since\n // it may be called before any cordova JS is ready.\n if (window._nativeReady) {\n channel.onNativeReady.fire();\n }\n\n /**\n * Create all cordova objects once page has fully loaded and native side is ready.\n */\n channel.join(function() {\n var builder = require('cordova/builder'),\n platform = require('cordova/platform');\n\n builder.buildIntoButDoNotClobber(platform.defaults, context);\n builder.buildIntoAndClobber(platform.clobbers, context);\n builder.buildIntoAndMerge(platform.merges, context);\n\n // Call the platform-specific initialization\n platform.initialize();\n\n // Fire event to notify that all objects are created\n channel.onCordovaReady.fire();\n\n // Fire onDeviceReady event once all constructors have run and\n // cordova info has been received from native side.\n channel.join(function() {\n require('cordova').fireDocumentEvent('deviceready');\n }, channel.deviceReadyChannelsArray);\n\n }, [ channel.onDOMContentLoaded, channel.onNativeReady, channel.onPluginsReady ]);\n\n}(window));\n\n//@ sourceURL=lib/scripts/bootstrap.js")} catch(e) {console.log("exception: in lib/scripts/bootstrap.js: " + e);console.log(e.stack);}
try {eval("\nrequire('cordova/channel').onNativeReady.fire();\n\n//@ sourceURL=lib/scripts/bootstrap-webos.js")} catch(e) {console.log("exception: in lib/scripts/bootstrap-webos.js: " + e);console.log(e.stack);}
-try {eval("\n// Tries to load all plugins' js-modules.\n// This is an async process, but onDeviceReady is blocked on onPluginsReady.\n// onPluginsReady is fired when there are no plugins to load, or they are all done.\n(function (context) {\n // To be populated with the handler by handlePluginsObject.\n var onScriptLoadingComplete;\n\n var scriptCounter = 0;\n function scriptLoadedCallback() {\n scriptCounter--;\n if (scriptCounter === 0) {\n onScriptLoadingComplete && onScriptLoadingComplete();\n }\n }\n\n // Helper function to inject a <script> tag.\n function injectScript(path) {\n scriptCounter++;\n var script = document.createElement(\"script\");\n script.onload = scriptLoadedCallback;\n script.src = path;\n document.head.appendChild(script);\n }\n\n // Called when:\n // * There are plugins defined and all plugins are finished loading.\n // * There are no plugins to load.\n function finishPluginLoading() {\n context.cordova.require('cordova/channel').onPluginsReady.fire();\n }\n\n // Handler for the cordova_plugins.json content.\n // See plugman's plugin_loader.js for the details of this object.\n // This function is only called if the really is a plugins array that isn't empty.\n // Otherwise the XHR response handler will just call finishPluginLoading().\n function handlePluginsObject(modules) {\n // First create the callback for when all plugins are loaded.\n var mapper = context.cordova.require('cordova/modulemapper');\n onScriptLoadingComplete = function() {\n // Loop through all the plugins and then through their clobbers and merges.\n for (var i = 0; i < modules.length; i++) {\n var module = modules[i];\n if (!module) continue;\n\n if (module.clobbers && module.clobbers.length) {\n for (var j = 0; j < module.clobbers.length; j++) {\n mapper.clobbers(module.id, module.clobbers[j]);\n }\n }\n\n if (module.merges && module.merges.length) {\n for (var k = 0; k < module.merges.length; k++) {\n mapper.merges(module.id, module.merges[k]);\n }\n }\n\n // Finally, if runs is truthy we want to simply require() the module.\n // This can be skipped if it had any merges or clobbers, though,\n // since the mapper will already have required the module.\n if (module.runs && !(module.clobbers && module.clobbers.length) && !(module.merges && module.merges.length)) {\n context.cordova.require(module.id);\n }\n }\n\n finishPluginLoading();\n };\n\n // Now inject the scripts.\n for (var i = 0; i < modules.length; i++) {\n injectScript(modules[i].file);\n }\n }\n\n // Try to XHR the cordova_plugins.json file asynchronously.\n var xhr = new context.XMLHttpRequest();\n xhr.onreadystatechange = function() {\n if (this.readyState != 4) { // not DONE\n return;\n }\n\n // If the response is a JSON string which composes an array, call handlePluginsObject.\n // If the request fails, or the response is not a JSON array, just call finishPluginLoading.\n if (this.status == 200) {\n var obj = JSON.parse(this.responseText);\n if (obj && obj instanceof Array && obj.length > 0) {\n handlePluginsObject(obj);\n } else {\n finishPluginLoading();\n }\n } else {\n finishPluginLoading();\n }\n };\n xhr.open('GET', 'cordova_plugins.json', true); // Async\n xhr.send();\n}(window));\n\n\n//@ sourceURL=lib/scripts/plugin_loader.js")} catch(e) {console.log("exception: in lib/scripts/plugin_loader.js: " + e);console.log(e.stack);}
+try {eval("\n// Tries to load all plugins' js-modules.\n// This is an async process, but onDeviceReady is blocked on onPluginsReady.\n// onPluginsReady is fired when there are no plugins to load, or they are all done.\n(function (context) {\n // To be populated with the handler by handlePluginsObject.\n var onScriptLoadingComplete;\n\n var scriptCounter = 0;\n function scriptLoadedCallback() {\n scriptCounter--;\n if (scriptCounter === 0) {\n onScriptLoadingComplete && onScriptLoadingComplete();\n }\n }\n\n // Helper function to inject a <script> tag.\n function injectScript(path) {\n scriptCounter++;\n var script = document.createElement(\"script\");\n script.onload = scriptLoadedCallback;\n script.src = path;\n document.head.appendChild(script);\n }\n\n // Called when:\n // * There are plugins defined and all plugins are finished loading.\n // * There are no plugins to load.\n function finishPluginLoading() {\n context.cordova.require('cordova/channel').onPluginsReady.fire();\n }\n\n // Handler for the cordova_plugins.json content.\n // See plugman's plugin_loader.js for the details of this object.\n // This function is only called if the really is a plugins array that isn't empty.\n // Otherwise the XHR response handler will just call finishPluginLoading().\n function handlePluginsObject(modules) {\n // First create the callback for when all plugins are loaded.\n var mapper = context.cordova.require('cordova/modulemapper');\n onScriptLoadingComplete = function() {\n // Loop through all the plugins and then through their clobbers and merges.\n for (var i = 0; i < modules.length; i++) {\n var module = modules[i];\n if (!module) continue;\n\n if (module.clobbers && module.clobbers.length) {\n for (var j = 0; j < module.clobbers.length; j++) {\n mapper.clobbers(module.id, module.clobbers[j]);\n }\n }\n\n if (module.merges && module.merges.length) {\n for (var k = 0; k < module.merges.length; k++) {\n mapper.merges(module.id, module.merges[k]);\n }\n }\n\n // Finally, if runs is truthy we want to simply require() the module.\n // This can be skipped if it had any merges or clobbers, though,\n // since the mapper will already have required the module.\n if (module.runs && !(module.clobbers && module.clobbers.length) && !(module.merges && module.merges.length)) {\n context.cordova.require(module.id);\n }\n }\n\n finishPluginLoading();\n };\n\n // Now inject the scripts.\n for (var i = 0; i < modules.length; i++) {\n injectScript(modules[i].file);\n }\n }\n\n\n // Try to XHR the cordova_plugins.json file asynchronously.\n try { // we commented we were going to try, so let us actually try and catch \n var xhr = new context.XMLHttpRequest();\n xhr.onload = function() {\n // If the response is a JSON string which composes an array, call handlePluginsObject.\n // If the request fails, or the response is not a JSON array, just call finishPluginLoading.\n var obj = JSON.parse(this.responseText);\n if (obj && obj instanceof Array && obj.length > 0) {\n handlePluginsObject(obj);\n } else {\n finishPluginLoading();\n }\n };\n xhr.onerror = function() {\n finishPluginLoading();\n };\n xhr.open('GET', 'cordova_plugins.json', true); // Async\n xhr.send();\n }\n catch(err){\n finishPluginLoading();\n }\n}(window));\n\n\n//@ sourceURL=lib/scripts/plugin_loader.js")} catch(e) {console.log("exception: in lib/scripts/plugin_loader.js: " + e);console.log(e.stack);}
})();
\ No newline at end of file
diff --git a/lib/cordova.webos.js b/lib/cordova.webos.js
index 614b1fa..3251823 100644
--- a/lib/cordova.webos.js
+++ b/lib/cordova.webos.js
@@ -1,8 +1,8 @@
// Platform: webos
-// commit bbf1562d4934b1331ffb263424b6ae054cedeb71
+// commit 4bbb9b5e9f232cc5f090e5065a0d92086b78628d
-// File generated at :: Thu Mar 21 2013 14:40:07 GMT-0700 (PDT)
+// File generated at :: Wed Mar 27 2013 15:35:48 GMT-0700 (PDT)
/*
Licensed to the Apache Software Foundation (ASF) under one
@@ -924,6 +924,8 @@
// file: lib/webos/platform.js
define("cordova/platform", function(require, exports, module) {
+/*global Mojo:false */
+
var service=require('cordova/plugin/webos/service'),
cordova = require('cordova');
@@ -933,13 +935,6 @@
var modulemapper = require('cordova/modulemapper');
modulemapper.loadMatchingModules(/cordova.*\/symbols$/);
-
- modulemapper.merges('cordova/plugin/webos/service', 'navigator.service');
- modulemapper.merges('cordova/plugin/webos/application', 'navigator.application');
- modulemapper.merges('cordova/plugin/webos/window', 'navigator.window');
- modulemapper.merges('cordova/plugin/webos/orientation', 'navigator.orientation');
- modulemapper.merges('cordova/plugin/webos/keyboard', 'navigator.keyboard');
-
modulemapper.mapModules(window);
if (window.PalmSystem) {
@@ -1011,6 +1006,27 @@
});
});
+ },
+ merges: {
+ navigator: {
+ children: {
+ service: {
+ path: "cordova/plugin/webos/service"
+ },
+ application: {
+ path: "cordova/plugin/webos/application"
+ },
+ window: {
+ path: "cordova/plugin/webos/window"
+ },
+ orientation: {
+ path: "cordova/plugin/webos/orientation"
+ },
+ keyboard: {
+ path: "cordova/plugin/webos/keyboard"
+ }
+ }
+ }
}
};
@@ -2619,7 +2635,7 @@
var origin = protocol + url.host;
// check whether there are the username:password credentials in the url
- if (url.href.indexOf(origin) != 0) { // credentials found
+ if (url.href.indexOf(origin) !== 0) { // credentials found
var atIndex = url.href.indexOf("@");
credentials = url.href.substring(protocol.length, atIndex);
}
@@ -2668,15 +2684,11 @@
var params = null;
var chunkedMode = true;
var headers = null;
-
+ var httpMethod = null;
var basicAuthHeader = getBasicAuthHeader(server);
if (basicAuthHeader) {
- if (!options) {
- options = new FileUploadOptions();
- }
- if (!options.headers) {
- options.headers = {};
- }
+ options = options || {};
+ options.headers = options.headers || {};
options.headers[basicAuthHeader.name] = basicAuthHeader.value;
}
@@ -2685,6 +2697,12 @@
fileName = options.fileName;
mimeType = options.mimeType;
headers = options.headers;
+ httpMethod = options.httpMethod || "POST";
+ if (httpMethod.toUpperCase() == "PUT"){
+ httpMethod = "PUT";
+ } else {
+ httpMethod = "POST";
+ }
if (options.chunkedMode !== null || typeof options.chunkedMode != "undefined") {
chunkedMode = options.chunkedMode;
}
@@ -2711,7 +2729,7 @@
successCallback && successCallback(result);
}
};
- exec(win, fail, 'FileTransfer', 'upload', [filePath, server, fileKey, fileName, mimeType, params, trustAllHosts, chunkedMode, headers, this._id]);
+ exec(win, fail, 'FileTransfer', 'upload', [filePath, server, fileKey, fileName, mimeType, params, trustAllHosts, chunkedMode, headers, this._id, httpMethod]);
};
/**
@@ -2729,12 +2747,8 @@
var basicAuthHeader = getBasicAuthHeader(source);
if (basicAuthHeader) {
- if (!options) {
- options = {};
- }
- if (!options.headers) {
- options.headers = {};
- }
+ options = options || {};
+ options.headers = options.headers || {};
options.headers[basicAuthHeader.name] = basicAuthHeader.value;
}
@@ -2773,12 +2787,11 @@
};
/**
- * Aborts the ongoing file transfer on this object
- * @param successCallback {Function} Callback to be invoked upon success
- * @param errorCallback {Function} Callback to be invoked upon error
+ * Aborts the ongoing file transfer on this object. The original error
+ * callback for the file transfer will be called if necessary.
*/
-FileTransfer.prototype.abort = function(successCallback, errorCallback) {
- exec(successCallback, errorCallback, 'FileTransfer', 'abort', [this._id]);
+FileTransfer.prototype.abort = function() {
+ exec(null, null, 'FileTransfer', 'abort', [this._id]);
};
module.exports = FileTransfer;
@@ -2822,12 +2835,13 @@
* @param headers {Object} Keys are header names, values are header values. Multiple
* headers of the same name are not supported.
*/
-var FileUploadOptions = function(fileKey, fileName, mimeType, params, headers) {
+var FileUploadOptions = function(fileKey, fileName, mimeType, params, headers, httpMethod) {
this.fileKey = fileKey || null;
this.fileName = fileName || null;
this.mimeType = mimeType || null;
this.params = params || null;
this.headers = headers || null;
+ this.httpMethod = httpMethod || null;
};
module.exports = FileUploadOptions;
@@ -3190,6 +3204,34 @@
if (eventname in this.channels) {
this.channels[eventname].unsubscribe(f);
}
+ },
+ executeScript: function(injectDetails, cb) {
+ var script,
+ sourceString;
+ if (injectDetails.code) {
+ exec(cb, null, "InAppBrowser", "injectScriptCode", [injectDetails.code]);
+ } else if (injectDetails.file) {
+ sourceString = JSON.stringify(injectDetails.file);
+ script = "(function(d) { var c = d.createElement('script'); c.src = " + sourceString + "; d.body.appendChild(c); })(document)";
+ exec(cb, null, "InAppBrowser", "injectScriptCode", [script]);
+ } else {
+ throw new Error('executeScript requires exactly one of code or file to be specified');
+ }
+ },
+ insertCSS: function(injectDetails, cb) {
+ var script,
+ sourceString;
+ if (injectDetails.code) {
+ sourceString = JSON.stringify(injectDetails.code);
+ script = "(function(d) { var c = d.createElement('style'); c.innerHTML = " + sourceString + "; d.body.appendChild(c); })(document)";
+ exec(cb, null, "InAppBrowser", "injectScriptCode", [script]);
+ } else if (injectDetails.file) {
+ sourceString = JSON.stringify(injectDetails.file);
+ script = "(function(d) { var c = d.createElement('link'); c.rel='stylesheet', c.type='text/css'; c.href = " + sourceString + "; d.body.appendChild(c); })(document)";
+ exec(cb, null, "InAppBrowser", "injectScriptCode", [script]);
+ } else {
+ throw new Error('insertCSS requires exactly one of code or file to be specified');
+ }
}
};
@@ -6791,28 +6833,29 @@
}
}
- // Try to XHR the cordova_plugins.json file asynchronously.
- var xhr = new context.XMLHttpRequest();
- xhr.onreadystatechange = function() {
- if (this.readyState != 4) { // not DONE
- return;
- }
- // If the response is a JSON string which composes an array, call handlePluginsObject.
- // If the request fails, or the response is not a JSON array, just call finishPluginLoading.
- if (this.status == 200) {
+ // Try to XHR the cordova_plugins.json file asynchronously.
+ try { // we commented we were going to try, so let us actually try and catch
+ var xhr = new context.XMLHttpRequest();
+ xhr.onload = function() {
+ // If the response is a JSON string which composes an array, call handlePluginsObject.
+ // If the request fails, or the response is not a JSON array, just call finishPluginLoading.
var obj = JSON.parse(this.responseText);
if (obj && obj instanceof Array && obj.length > 0) {
handlePluginsObject(obj);
} else {
finishPluginLoading();
}
- } else {
+ };
+ xhr.onerror = function() {
finishPluginLoading();
- }
- };
- xhr.open('GET', 'cordova_plugins.json', true); // Async
- xhr.send();
+ };
+ xhr.open('GET', 'cordova_plugins.json', true); // Async
+ xhr.send();
+ }
+ catch(err){
+ finishPluginLoading();
+ }
}(window));