Note: This project page is a work in progress. Please reach out on the gitter chat if you would like to contribute to this project
Create a prototype Progressive Web App using Angular & CouchDB with the BeLL Apps functionality
- Working on a component
Including
- Writing front end code
- Helping with unit tests
- Helping with e2e tests
- Making this project "Offline First"
- Making the app secure with SSL
- You should have Vagrant installed already, but if not follow the instructions here up to Install a communityBeLL on your OS to install Vagrant
- Clone the planet repository
- Run
vagrant up
in the repo directory - After the virtual machine has been installed & a few more seconds to compile the code you can visit the application at
localhost:3000
- To run additional commands, you will need to ssh into the virtual machine with
vagrant ssh
and thencd /vagrant
to get into the project directory - When you are done working, you can shut down the machine with
vagrant halt
if you'd like to
Some additional commands:
This project is built with the Angular CLI, and once you are in the working directory in the virtual machine you can use any of the commands available with the CLI. Most often you'll be using one of the testing commands:
ng test
Will run unit tests which are available atlocalhost:9876
after compiling.ng e2e
Will run end to end tests which are available atlocalhost:49152
after compiling.
Once you have the app up and running, you can start working on a component! Feel free to post to the Gitter chat or check out the Angular docs if you need some guidance on Angular or JavaScript. Here we'll focus on some key points you should be aware of.
To keep things organized but not have too deep of a folder structure, our app structure looks like this:
src/
|--app/
|--<features>/ <-- Various folders each containing a distinct feature. Generally should match up with what is found on the navigation bar.
| |--<secondary features>/ <-- If the primary folder is getting or will be cluttered, split up the files further into distinct secondary features.
|--home/ <-- Contains navigation components in addition to dashboard
|--login/ <-- Contains login & registration
|--shared/ <-- Contains services & components to be used in more than one module
This project is using SCSS/Sass, which is a CSS preprocessor. You can read more about it here.
We're keeping the variables all in one file /src/app/variables.scss
and if you write a mixin please put it in a similar /src/app/mixins.scss
file so others can use them.
In general, please try to write broader styles that can work across many components. Having classes like meetup-button
and resource-form
might make sense at a glance, but either end up being:
- Just thrown into other components and confusing to read. OR
- Copied entirely or with minor adjustments and renamed
It's either bad for readability or unnecessary repetition.
Broad app styles can be found & added to in /src/styles.scss
If you end up having some component specific styles, make sure to read up on component styles in the Angular docs first.
Most components will eventually need to access the database. If you are unfamiliar with CouchDB, check out the documentation here.
There is a single service for accessing CouchDB in the shared folder that you can import to your component for accessing CouchDB. It is very basic and flexible, allowing you to create an HTTP request for the CouchDB and returning the response as a JavaScript object. You can import it with the line:
import { CouchService } from '../shared/couchdb.service';
This service has four public methods: get
, post
, put
, and delete
. The CouchDB docs are very helpful to let you know which to use, so take a look there if you are unsure.
Here's a quick rundown of the parameters used in these methods:
db
: Is a string representing the database to modify. Note the service already includes the first/
. For example rather than/_session
write_session
.data
: Is used inpost
andput
only and is an object with data to send to CouchDB.opts
: Optional Adds options to the HTTP request.
Each component that is built should have a corresponding unit test with a .spec.ts
file extension. Unit tests are written in Jasmine and use the Karma test runner, like the examples in the Angular docs. The guide covers quite a bit, so we'll highlight one section here: spies.
A unit test of an Angular component should not involve calls to the database to retreive data (this would fall under end to end tests), but sometimes functionality needs to be tested that would make a call to the database (i.e. login success/failure messages). One option to avoid using the database that Jasmine provides is the spy
. Spies allow you to track a function and supply a return value. When that function is called within the test, the spy takes over and simply returns the provided value rather than executing the function.
As mentioned in the Angular docs, there are other ways to circumvent using the database in unit tests, but spies are a good place to start.
We'd like to create an app that will work in various locales which have no or intermittent internet connections. The goal is to have an instance of PouchDB running within the browser which allows the user to do everything within the BeLL-Apps and when connectivity is available will talk back and forth with the CouchDB server.
A possible implementation would be to use Service Workers. The first portion of this presentation covers Service Workers and how they work within a browser to create functional offline experiences. There is a plugin for PouchDB for working with Service Workers which may be the solution here.
One of the big things to think about in this regard is merge conflicts, and PouchDB has a good article on possible strategies.
Here are some links to some free courses which will help you learn more about Progressive Web Apps:
- https://codelabs.developers.google.com/codelabs/your-first-pwapp
- https://www.udacity.com/course/intro-to-progressive-web-apps--ud811
WIP