You need a mobile app fast. What are you going to do?
The boss has just rushed into your office and said, "We need a mobile app for our salespeople to use, and we need it soon!" And before you can ask her just what she means by "mobile app" and what, exactly, the salespeople need, she's gone.
A little research and you find that you have basically three options:
- Create native mobile apps
- Create hybrid apps
- Create responsive web apps
Which option will support the broadest range of devices, and which option will allow you to deliver it "soon"? Back to the Google answer man....
Native Mobile Applications
Native mobile applications have the advantage of performance. You will be able to develop apps that are closer to the "metal," and that means speed and device compatibility will be better. But it also means that you will be developing applications in different languages and IDEs. At minimum, you'll be dealing with Objective C and Xcode for Apple devices and Java and Eclipse/Android SDK for Android devices. The good news is that you won't need to spend much on the Android side of things. Eclipse and the Android SDK are free and open source. For Apple, you'll be out at least $100 for a developer license, and you'll need a Mac to compile your code. There some "open-source" projects in the Apple world (Swift, Webkit, and don't forget that Mac OS is a UNIX derivative), but you'll need to dig a bit if you choose to develop for Apple devices.
Native mobile applications have the disadvantage of an approval process if you want to make your app available in iTunes or Google Play store. You have to play by their rules to get approval, and if you find a bug and need to tweak the app, you go through the whole process again. So, early on, as your release cycles are frequent, you'll be waiting on Apple and Google to vet your app so you can release new code. There are alternatives: you can release new Android apps just by making the APK files available (and changing some device security settings). Apple requires an upcharge for an Enterprise developer license that allows you to distribute without using iTunes. Both options can be used but require more user installation support. If you distribute through iTunes or Google Play, then your app will join millions of other "zombie" apps taking up space in these distribution channels.
Hybrid Mobile Applications
Responsive Web Applications
You could go the route of responsive design, which would involve re-engineering your existing website so that it's more "device aware," and could adapt the look and feel to the architecture of the device and browser. You'll discover that there are plenty of open-source resources, libraries, and frameworks available to help in the process. You'll end up with a single website that can serve both your traditional desktop users and your mobile users, and you won't have to use an intermediary to deploy the application. There are possibilities here.
Which Way to Go?
So, how to make a decision with so many variables? You decide to make a list of the application requirements and then decide which of the options support the requirement and which will be the easiest and fastest to implement.
- Real-time access to IBM i data and local storage when no mobile connectivity is available
- Ability to take pictures, store them on the device, and upload them
- Ability to retrieve and store geolocation information
- Ability to record audio for taking "audio notes"
Your plan is to concentrate on the pages used most by your salespeople and re-work them into a more responsive design first by adding the jQuery Mobile open-source library. Your next step will be to create the pages that will support access to camera and microphone. And, finally, you can add local storage to your web application so that the data will be stored locally on the mobile device or desktop and uploaded as needed.
You breathe a sigh of relief! This won't be nearly as difficult as you first thought. You'll leverage skills your shop already has. There will be no need for additional language learning or unpacking the intricacies of an IDE or new framework. Using PHP and CGIDEV2, you can just refactor and re-engineer some existing web pages with the long-term goal of making everything responsive, a page at a time.
Time to drop an email to your frantic boss: you have this covered!