Ngbp
A sophisticated build management system for web apps (formerly ng-boilerplate). Created by @joshdmiller
Install / Use
/learn @ngbp/NgbpREADME
ngBoilerplate 
An opinionated kickstarter for AngularJS projects.
Quick Start
Install Node.js and then:
$ git clone git://github.com/joshdmiller/ng-boilerplate
$ cd ng-boilerplate
$ sudo npm -g install grunt-cli karma bower
$ npm install
$ bower install
$ grunt watch
Finally, open file:///path/to/ng-boilerplate/build/index.html in your browser.
Happy hacking!
Purpose
ngBoilerplate is designed to make life easy by providing a basic framework
with which to kickstart AngularJS projects. It contains a best-practice
directory structure to ensure code reusability and maximum scalability.
ngBoilerplate also comes prepackaged with the most popular design frameworks
around: Twitter Bootstrap,
Angular UI,
Angular Bootstrap,
Font Awesome, and
LESS. Lastly, it contains a sophisticated
Grunt-based build system to ensure maximum productivity.
All you have to do is clone it and start coding!
Philosophy
The principal goal of ngBoilerplate is to set projects up for long-term
success. So ngBoilerplate tries to follow best practices everywhere it can.
These are:
- Properly orchestrated modules to encourage drag-and-drop component re-use.
- Tests exist alongside the component they are testing with no separate
testdirectory required; the build process should be sophisticated enough to handle this. - Speaking of which, the build system should work automagically, without involvement from the developer. It should do what needs to be done, while staying out of the way. Components should end up tested, linted, compiled, and minified, ready for use in a production environment.
- Integration with popular tools like Bower, Karma, and LESS.
- Encourages test-driven development. It's the only way to code.
- A directory structure that is cogent, meaningful to new team members, and supporting of the above points.
- Well-documented, to show new developers why things are set up the way they are.
- It should be responsive to evidence. Community feedback is therefore crucial
to the success of
ngBoilerplate.
But ngBoilerplate is not an example of an AngularJS app: this is a
kickstarter. If you're looking for an example of what a complete, non-trivial
AngularJS app that does something real looks like, complete with a REST backend
and authentication and authorization, then take a look at
angular-app, which does just
that - and does it well.
Learn
Overall Directory Structure
At a high level, the structure looks roughly like this:
ng-boilerplate/
|- grunt-tasks/
|- karma/
|- src/
| |- app/
| | |- <app logic>
| |- assets/
| | |- <static files>
| |- common/
| | |- <reusable code>
| |- less/
| | |- main.less
|- vendor/
| |- angular-bootstrap/
| |- bootstrap/
| |- placeholders/
|- .bowerrc
|- bower.json
|- build.config.js
|- Gruntfile.js
|- module.prefix
|- module.suffix
|- package.json
What follows is a brief description of each entry, but most directories contain
their own README.md file with additional documentation, so browse around to
learn more.
karma/- test configuration.src/- our application sources. Read more »vendor/- third-party libraries. Bower will install packages here. Anything added to this directory will need to be manually added tobuild.config.jsandkarma/karma-unit.jsto be picked up by the build system..bowerrc- the Bower configuration file. This tells Bower to install components into thevendor/directory.bower.json- this is our project configuration for Bower and it contains the list of Bower dependencies we need.build.config.js- our customizable build settings; see "The Build System" below.Gruntfile.js- our build script; see "The Build System" below.module.prefixandmodule.suffix- our compiled application script is wrapped in these, which by default are used to place the application inside a self-executing anonymous function to ensure no clashes with other libraries.package.json- metadata about the app, used by NPM and our build script. Our NPM dependencies are listed here.
Detailed Installation
This section provides a little more detailed understanding of what goes into
getting ngBoilerplate up and running. Though ngBoilerplate is really simple
to use, it might help to have an understanding of the tools involved here, like
Node.js and Grunt and Bower. If you're completely new to highly organized,
modern JavaScript development, take a few short minutes to read this overview
of the tools before continuing with this section.
Okay, ready to go? Here it is:
ngBoilerplate uses Grunt as its build system, so
Node.js is required. Also, Grunt by default no longer comes
with a command-line utility and Karma and Bower must end up in your global path
for the build system to find it, so they must be installed independently. Once
you have Node.js installed, you can simply use npm to make it all happen:
$ npm -g install grunt-cli karma bower
If you're on Linux (like I am) then throw sudo in front of that command. If
you're on Windows, then you're on your own.
Next, you can either clone this repository using Git, download it as a zip file from GitHub, or merge the branch into your existing repository. Assuming you're starting from scratch, simply clone this repository using git:
$ git clone git://github.com/joshdmiller/ng-boilerplate my-project-name
$ cd my-project-name
And then install the remaining build dependencies locally:
$ npm install
This will read the dependencies (empty by default) and the devDependencies
(which contains our build requirements) from package.json and install
everything needed into a folder called node_modules/.
There are many Bower packages used by ngBoilerplate, like Twitter Bootstrap
and Angular UI, which are listed in bower.js. To install them into the
vendor/ directory, simply run:
$ bower install
In the future, should you want to add a new Bower package to your app, run the
install command:
$ bower install packagename --save-dev
The --save-dev flag tells Bower to add the package at its current version to
our project's bower.js file so should another developer download our
application (or we download it from a different computer), we can simply run the
bower install command as above and all our dependencies will be installed for
us. Neat!
Technically, ngBoilerplate is now ready to go.
However, prior to hacking on your application, you will want to modify the
package.json file to contain your project's information. Do not remove any
items from the devDependencies array as all are needed for the build process
to work.
To ensure your setup works, launch grunt:
$ grunt watch
The built files are placed in the build/ directory by default. Open the
build/index.html file in your browser and check it out! Because everything is
compiled, no XHR requests are needed to retrieve templates, so until this needs
to communicate with your backend there is no need to run it from a web server.
watch is actually an alias of the grunt-contrib-watch that will first run a
partial build before watching for file changes. With this setup, any file that
changes will trigger only those build tasks necessary to bring the app up to
date. For example, when a template file changes, the templates are recompiled
and concatenated, but when a test/spec file changes, only the tests are run.
This allows the watch command to complete in a fraction of the time it would
ordinarily take.
In addition, if you're running a Live Reload plugin in your browser (see below),
you won't even have to refresh to see the changes! When the watch task detects
a file change, it will reload the page for you. Sweet.
When you're ready to push your app into production, just run the compile
command:
$ grunt compile
This will concatenate and minify your sources and place them by default into the
bin/ directory. There will only be three files: index.html,
your-app-name.js, and your-app-name.css. All of the vendor dependencies like
Bootstrap styles and AngularJS itself have been added to them for super-easy
deploying. If you use any assets (src/assets/) then they will be copied to
bin/ as is.
Lastly, a complete build is always available by simply running the default
task, which runs build and then compile:
$ grunt
The Build System
The best way to learn about the build system is by familiarizing yourself with
Grunt and then reading through the heavily documented build script,
Gruntfile.js. But you don't need to do that to be very productive with
ngBoilerplate. What follows in this section is a quick introduction to the
tasks provided and should be plenty to get you started.
The driver of the process is the delta multi-task, which watches for file
changes using grunt-contrib-watch and executes one of nine tasks when a file
changes:
delta:gruntfile- WhenGruntfile.jschanges, this task runs the linter (jshint) on that one file and reloads the configuration.delta:assets- When any file withinsrc/assets/changes, all asset files are copied tobuild/assets/.delta:html- Whensrc/index.htmlchanges, it is compiled as a Grunt template, so script names, etc., are dynamically replaced with the correct values configured dynamica
