In this workshop, we are going to go through the process of building a hybrid mobile app using Ionic Framework.
This repo will serve as a guide and in this README.md
, you can find all the steps and instructions needed to build the app.
- Here you can find the slides of the presentation at the JSConfUY 2015
- Here you can find a hosted version of the app we are going to build
- You can also deploy your own copy of the app using this button:
- This is the ID (
7364750e
) of the JSConfUY app on Ionic View. If you want to test the app in your device, you can follow these steps and get the app through Ionic View - If you are an Android user, you can download the
.apk
here
Notice:
- This is not a mobile web; after compiled, you will get a native app that uses web technologies (JS, CSS, HTML). The hosted example is just for you to see how the app is going to be, but remember that what you are going to see in the hosted version is a pre-build example of the app; all the interactions with native mobile APIs (inAppBrowser, Social Share, etc.) won't be available.
- Ionic View is meant to provide an easy way to share and try mobile apps built with Ionic. That said, there are some Cordova plugins that are not yet integrated in Ionic View. That may cause some functionalities to not work if you are trying the app on Ionic View.
- For a better experience, we recommend you download the app from the App Store or Google Play or to download the
.apk
if you are an Android user. - For more information about using Heroku, check out https://devcenter.heroku.com/
Are you using Windows? It is probable that you will get some errors when running npm install
because your computer needs some other things to use npm
. Stay calm, you are not alone! If that's the case, please look at these links to fix your issues and then continue with the rest of the installation process below.
You can find the Ionic official installation documentation here.
- Make sure you have an up-to-date version of Node.js installed on your system. If you don't have Node.js installed, you can install it from here.
- Open a terminal (Mac) or a command interpreter (
cmd
, Windows), and install Cordova and Ionic:npm install -g cordova
npm install -g ionic
- On a Mac, you may have to use
sudo
depending on your system configuration:sudo npm install -g cordova ionic
- If you already have Cordova and Ionic installed on your computer, make sure you update to the latest version:
npm update -g cordova
npm update -g ionic
- Or
sudo npm update -g cordova ionic
Follow these links if you want more information:
This step corresponds with this slide of the presentation.
First we need to link this new Ionic project with our reference repo on github. Clone and checkout the initial commit (e37d84e
) of this repo so we can start working on the app:
git clone https://github.com/startapplabs/jsconfuy.git
cd jsconfuy
git checkout e37d84e
After this, we need to set up some stuff before starting working on the Ionic project. To do so, run these commands:
npm install
bower install
ionic setup sass
Note: If you are starting a brand new project with Ionic, run these commands instead:
ionic start jsconfuy sidemenu
cd jsconfuy
ionic setup sass
Finally, to see the current state of the project, run:
ionic serve
If you followed the procedure above, after serving the app, you can see that the Ionic dev server is running on http://localhost:8100
and there, you will see one of Ionic's starter projects, which showcases an app with a side menu.
- Bind the project to an existing Github repo
- Start and perform basic configurations for your Ionic project using the powerful Ionic CLI
- Serve and see your app running on Ionic dev server which includes:
- Live reload: every time you change a file, you will see the changes without refreshing
- Tasks and watchers: every time you change a file, Gulp tasks running on the background will perform certain procedures that will ease the development (for example sass compilation and minification)
This step corresponds with this slide of the presentation, and this commit (e8d787b
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout e8d787b
In this step, we are going to remove all the example files that came with the Ionic starter project and add our own starter files.
This app will have information about Uruguay's Javascript Conference 2015 (JSConfUY 2015). To serve that purpose, the content will be the following:
- 3 main views containing
- Speakers information
- Venue information
- Agenda information
- 1 side menu for a clear navigation
- 1 sub view to show extended information of events such as keynotes, talks, workshops, coffee breaks, etc.
This image illustrates the navigation between views
To achieve this, we are going to:
- Add
www/templates/agenda.html
with basic agenda view layout - Add
www/templates/speakers.html
with basic speakers view layout - Add
www/templates/venue.html
with basic venue view layout - Add
www/templates/event.html
with basic event view layout - Update
www/templates/menu.html
with navigation layout to the other views - Update
www/js/app.js
with app's desired routing - Update
www/js/controllers.js
with a basic controller for each view
The final point of this step is this commit (296941e
). Run git checkout 296941e
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There you will see our JSConfUY app with the navigation DONE.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (e8d787b
) and the final commit (296941e
) of this step.
- Define custom routing for our app using AngularJS
ui-route
- Change the layout of our views using HTML
This step corresponds with this slide of the presentation, and this commit (296941e
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout 296941e
In this step we are going to work on the layout of the speakers view. For this view, we need to:
- Show a list with all the speakers of the conference
- Show information about the speaker
- Provide a quick link to the speaker's talk
- Provide a link to the speaker's social profiles
Luckily, Ionic provides awesome components that will help us layout the content. Ionic avatar list or thumbnails list may be good options, but I think Ionic cards are the best choice for this view because we can fit all the information we have within one clean component.
The final point of this step is this commit (fb02948
). Run git checkout fb02948
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY app with the speakers view DONE.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (296941e
) and the final commit (fb02948
) of this step.
- Explore Ionic components
- Compose different components to get the UI we want
This step corresponds with this slide of the presentation, and this commit (fb02948
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout fb02948
In this step, we are going to work on the layout of the venue view. For this view, we need to:
- Show a map pointing the location of the venue
- Show information about the location of the venue
As we mentioned before, one of the reasons Ionic is awesome is because it's built using the web stack. In this case, that means that we don't have to reinvent the wheel for the map we need for this view. We can easily reuse any angular map directive and it will work like a charm.
Angularjs-Google-Maps will do the trick. We just need to add the dependency using bower:
bower install ngmap --save
The final point of this step is this commit (7bfcf29
). Run git checkout -f 7bfcf29
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY app with the venue view and its map DONE.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (fb02948
) and the final commit (7bfcf29
) of this step.
- Use the web stack to build mobile apps
- Reuse AngularJS directives in our app
This step corresponds with this slide of the presentation, and this commit (7bfcf29
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout -f 7bfcf29
In this step we are going to work on the layout of the agenda view. For this view we need to:
- Show the schedule for both days of the conference
- Show information about each event
Again, Ionic has awesome components; in this case, tabs will work perfectly for displaying both days' schedule in a clean and organized manner.
The final point of this step is this commit (9d797d7
). Run git checkout 9d797d7
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY app with the agenda view and a tabs component showing both days' schedule.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (7bfcf29
) and the final commit (9d797d7
) of this step.
- Use advanced components such as tabs for our mobile app layout
This step corresponds with this slide of the presentation, and this commit (9d797d7
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout 9d797d7
In this step, we are going to remove all hard coded data and replace it with data we get from our data source (in this case, a simple JSON). We are going to:
- Define the structure and set all the data of the agenda.json data source
- Define the structure and set all the data of the speakers.json data source
- Grab images and resources from jsconf.uy website so we have rich content for our app
- Add
www/js/services.js
to get data from JSON data sources using AngularJS $http service - Add
www/js/filters.js
to display raw html - Add
www/js/directives.js
to use directive templates for agenda events - Update
www/js/controllers.js
to use the AngularJS services we defined inwww/js/services.js
In this step, we are using all the power of AngularJS controllers, directives, services, and filters to give real value to our app.
We are going to use underscore.js to ease our work; we just need to add the dependency using bower:
bower install underscore --save
Now we have an app that gets data from a data source and displays it dynamically to the users. In this case, we are using two JSON files as data sources, but you could easily use any other backend. The way many apps communicate with backend is through an API.
Having that in mind, in my opinion, you have three alternatives here:
- You can use almighty WordPress as your backend
- WordPress is very flexible and you can use it in many ways, as a blog, a cms, or ecommerce (using woocommerce, for example), etc. Also, there are tons of plugins that will help you add different functionalities.
- You can easily access your WordPress content through its JSON API.
- This is a fast and general solution, so depending on what you are planning to build, you may need something more powerful and custom.
- Use Parse or Firebase (both “backend as a service”)
- If you are one of those who like to have strict control over the backend implementation, I suggest you to try Strongloop.
- Strongloop is a perfect solution if you need full control and custom functionalities on your backend. Basically, it is a platform that enables you to easily (I would say VERY easily) build custom API’s for your backend needs. (This is the solution I use for my clients' production apps).
The final point of this step is this commit (14dd74a
). Run git checkout 14dd74a
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY app with real data for the event.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (9d797d7
) and the final commit (14dd74a
) of this step.
- Reuse what we already know from AngularJS (controllers, services, directives, filters) in our Ionic app
- Get data from different data sources
This step corresponds with this slide of the presentation, and this commit (14dd74a
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout 14dd74a
In this step, we are going to integrate some mobile native functionality using Cordova plugins and some Ionic UX components that will improve our app. We are going to:
- Add Cordova social sharing plugin to easily share talks with your friends
- Add Cordova inAppBrowser plugin to open social profiles of speakers
- Add Ionic loader
- Add Ionic slide box for speaker images
These are part of the so-called "ionic superpowers". Using Ionic to develop hybrid apps gives you the advantage of accessing the native API’s of devices, including the geolocation, social sharing, inAppBrowser, device camera, touchID, push notification, and so on. When developing an Ionic app, you can have several device API’s integrated using ngCordova or other Cordova plugins. That’s the difference between mobile web and hybrid apps.
To install these plugins, you just need to run:
cordova plugin add https://github.com/EddyVerbruggen/SocialSharing-PhoneGap-Plugin.git
cordova plugin add org.apache.cordova.inappbrowser
The final point of this step is this commit (73cec82
). Run git checkout 73cec82
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY app with the Ionic loader and slide box integrated but as you are accessing the app through the browser, you won't see either the social sharing plugin or the inAppBroswer plugin. You will need to install and test the app in your phone to see those in action.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (14dd74a
) and the final commit (73cec82
) of this step.
- Give superpowers to your app using Cordova plugins
- Give a more polished look to your app using Ionic UX components
This step corresponds with this slide of the presentation, and this commit (73cec82
) represents the starting point of this step. Please checkout this commit so we are all on the same page: git checkout 73cec82
In this step, we are going to take care of the app styles using CSS with the help of Sass. We are going to:
- Use Sass mixins
- Define and use Sass variables for fast customization
Mixins will ease our styles development by helping us with prefixing vendor properties, defining functions, etc., which will help us reuse our styles across the app.
This is the structure of the mixins we are going to use:
@mixin cssCalc($property, $expression) {
#{$property}: calc(#{$expression});
}
@mixin flexbox() {
display: -webkit-box;
display: -moz-box;
display: -ms-flexbox;
display: -webkit-flex;
display: flex;
}
@mixin flex-wrap($value) {
flex-wrap: $value;
-webkit-flex-wrap: $value;
}
Other awesome features are Sass variables. These will enable us to reuse variables across our style sheets. This is particularly useful, for example, when defining colors that will be spread across the app.
Here, you can see the variables we defined for our app, and how easily we can change those and immediately change the UI color scheme of the whole app.
$content-bg: #EAEAEA;
$content-color: #444444;
$top-bar-bg: #254164;
$top-bar-color: #FFFFFF;
$loading-color: #FFFFFF;
$main-menu-bg: #FFC900;
$main-menu-color: #FFFFFF;
$loading-color: #FFFFFF;
$speaker-actions-bg: #FFFFFF;
$workshop-bg-color: #00B454;
$talk-bg-color: #FF7C00;
$keynote-bg-color: #FF3900;
$global-bg-color: #DDDDDD;
$event-color: #FFFFFF;
$get-directions-btn-bg: #419e61;
$get-directions-btn-color: #FFFFFF;
The final point of this step is this commit (6eaea0f
). Run git checkout 6eaea0f
and you will see the implementation of the instructions above.
Serve the app with ionic serve
and look at the Ionic dev server running on http://localhost:8100
. There, you will see our JSConfUY finished with a professional and polished look.
If you want to see more details of what we have done, take a look at this comparison between the initial commit (73cec82
) and the final commit (6eaea0f
) of this step.
- Give a professional and polished look to our app
- Use some of the cool features of Sass (mixins, variables, etc.)
Please make sure you have node
version 0.10.36
You should fix your errors by reading these links: