Current phone development is at https://github.com/e-mission/e-mission-phone
This is the repo for the cross-platform UI, which we will build using apache cordova. The UI screens from here will be used to build the UI for the hybrid app stored in https://github.com/e-mission/e-mission-phone. Since we are embedding the cordova views, we need to create them in the context of a regular cordova app, and then copy them to the appropriate directory in the native app.
In order to build in the code in this directory, you need to first install apache cordova. We will use ionic for the UI, so we will install both the ionic and the cordova command line tools. http://ionicframework.com/getting-started/
Add the sqlite plugin to ensure that we can access the database from the javascript
$ ionic plugin add https://github.com/brodysoft/Cordova-SQLitePlugin
Add the whitelist plugin to ensure that we can access google maps from the javascript Otherwise, only loading from file URLs is supported, per: http://cordova.apache.org/announcements/2015/04/15/cordova-android-4.0.0.html
Network requests are blocked by default without the plugin, so install this plugin even to allow all requests, and even if you are using CSP.
$ ionic plugin add https://github.com/apache/cordova-plugin-whitelist.git#r1.0.0
The checked in version does not have the default ionic plugins installed, so on checking this out, you also need to install the following plugins
$ ionic plugin add com.ionic.keyboard
$ ionic plugin add org.apache.cordova.console
$ ionic plugin add org.apache.cordova.device
$ ionic plugin add org.apache.cordova.statusbar
In order to have this project work correctly on android, you need to have a recent version of the old ant-based SDK build tools available. The easiest way to do this is to use the SDK manager to install the most recent build tools.
Unlike a classic cordova app that has a single webview with all the screens, we
can potentially have multiple screens, one for each webview. In order to create
multiple top level screens in the same webview, we use the following structure
for the www
directory.
www
- screen1.html
- screen1-js/
- screen2.html
- screen2-js/
....
Then, we can create CordovaActivity
and EmbeddedCordovaView
screens in the main app that load screen1.html
, screen2.html
etc.
In order to create a new screen, the steps are:
- create
screen_new.html
andscreen-new-js/
in thewww
directory - edit config.xml to display
screen_new.html
- develop away
As described in https://github.com/e-mission/e-mission-phone/blob/master/README.md, after the screens are ready, the update_cordova_sources.sh
script can be run with this directory as the second argument. That will copy over the files to the appropriate locations on the native app repo, e.g.
$ ./update_cordova_sources.sh ~/e-mission/e-mission-phone-cordova/eMission
Since this is a web based UI, debugging occurs in the browser. The choice of browser depends upon the emulator - chrome is used to debug the android emulator and safari is used to debug the ios emulator.
- Open a new tab and enter chrome://inspect
- Choose the HTML file that you are debugging
- You can view log messages in the console, or set breakpoints and reload the HTML file
- Turn on Safari Developer mode https://developer.apple.com/safari/tools/
- Choose the process that you are debugging
- Again, you can view log messages in the console, or set breakpoints and reload the HTML file
The travel diary reads data from the local database, parses it, and displays the data as a list of trips and trip sections. The android and ios data are slightly different - one requires decoding from base64, and the other doesn't. So sample databases from both are checked in. The decoding is handled in the trip parsing, so it is sufficient to use one of them unless the parsing is being changed.
The one that is chosen should be copied to TripSections.db, i.e.
$ cp www/TripSections.android.db www/TripSections.db
before running listview.html