PhoneGap Palm is a skeleton Palm webOS application, along with javascript wrapper libraries, which allow a developer to build an application for a Palm webOS device using web technologies. This same code can be built for iPhone, BlackBerry, Symbian, and more to come ...
You should have VirtualBox (virtual machine software which runs the Palm emulator) and the webOS SDK installed. Both of these can be found at http://developer.palm.com/index.php?option=com_content&view=article&id=1545.
Open a terminal, and navigate to the root PhoneGap Palm folder (where this readme.md file is located). A Makefile resides here; running make here will package your application, and install it to either the emulator, or the device. Or you can run make on individual target tasks:
- make js - builds phonegap.js from source javascript files to libs/phonegap.js
- make copy_js - copies libs/phonegap.js to framework/phonegap.js - modify this path if you want phonegap.js in another location
- make package - builds the webOS app (located in framework/) into an webOS .ipk installer package in the phonegap_root/palm/ folder
- make deploy - installs the .ipk package to a device if detected, otherwise the emulator if its running
If a connected Palm device is detected, the application will be installed to the device. If not, and the emulator is running, the application will be installed to the emulator. To run the emulator, search for Palm Emulator.app in the finder, and run it.
Navigate to phonegap_root/webOS_new/framework/; this is where your application will reside. If you have already built a phonegap application on another platform, drop your html,js, css and assets into this folder (starting with the required index.html). Don't forget phonegap.js!
Just open framework/ in your favourite editor, build your web app, and run the appropriate make command indicated above. Edit appinfo.json to set your app id (see Notes below), version, etc.
Also, your index.html must indicate when the device is ready to run the WebOS application. Nested within the body tag of your index.html file include the following javascript code:
<script> var phonegap = new PhoneGap(); phonegap.deviceReady(); </script>To enable a javascript debug console, open a new terminal window and type: phonegap-log app_id Where the app id is your app id as set in appinfo.json. This will tail your log file; it will default to the device if detected, otherwise it will read logs from the emulator. In your javascript, use debug.log in your javascript.
- In order to use the vibration API on palm, your application needs to have a "com.palm.*" namespace, as vibration on webOS is a private API. The caveat of doing this is that you are essentially indicating that your app should pretend to be a "Palm app" (rather than a Nitobi app, for example) ... and as a result your app will be denied from the Palm app catalog.
- Currently the map.show function can only accept one position, as Palm uses google maps as its native maps application, and it only can take one marker as a parameter.
- Touch event not supported, natively. Must use the click event, or maybe we can emulate the touch event by capturing the click event.
- If using Lawnchair, the only supported adaptor is webkitsqlite.
- html select boxes are implemented by phonegap, not supported natively (believe it or not). only the most basic functionality is implemented, so be aware using this control could cause problems.
- To enable verbose logging, add the file framework_config.json to your framework/www/ folder, containing the following json content: { "logLevel": 99 }
- PhoneGap API Docs: docs.phonegap.com
- PhoneGap Wiki: phonegap.pbworks.com
- Palm webOS developer site: developer.palm.com