A Yeoman generator for creating modern web applications using Angular, SASS, Gulp, and Browserify.
Generator-angular-gulp-browserify is build on top of jakemmarsh/angularjs-gulp-browserify-boilerplate and provides a convenient way to bootstrap the original boilerplate.
# Install Yeoman, gulp & the generator:
npm install -g yo gulp generator-angular-gulp-browserify
# Make a new directory, and 'cd' into it:
mkdir my-project && cd $_
#To initialize the generator, run:
yo angular-gulp-browserify
#Finally, run:
gulp dev
Your browser will automatically be opened and directed to the browser-sync proxy address.
Now that gulp dev is running, the server is up as well and serving files from the /build
directory. Any changes in the /app
directory will be automatically processed by gulp and the changes will be injected to any open browsers pointed at the proxy address.
The complete project guide can be found in the official boilerplate readme.
The AngularJS files are all located within /app/js
, structured in the following manner:
/controllers
_index.js (the main module on which all controllers will be mounted, loaded in main.js)
example.js
/directives
_index.js (the main module on which all directives will be mounted, loaded in main.js)
example.js
/services
_index.js (the main module on which all services will be mounted, loaded in main.js)
example.js
constants.js (any constant values that you want to make available to Angular)
main.js (the main file read by Browserify, also where the application is defined and bootstrapped)
on_run.js (any functions or logic that need to be executed on app.run)
on_config.js (all route definitions and any logic that need to be executed on app.config)
templates.js (this is created via gulp by compiling your views, and will not be present beforehand)
- JSHint: gulp is currently configured to run a JSHint task before processing any Javascript files. This will show any errors in your code in the console, but will not prevent compilation or minification from occurring.
- Browserify: The main build process run on any Javascript files. This processes any of the
require('module')
statements, compiling the files as necessary. - Babelify: This uses babelJS to provide support for ES6+ features.
- Debowerify: Parses
require()
statements in your code, mapping them tobower_components
when necessary. This allows you to use and include bower components just as you would npm modules. - ngAnnotate: This will automatically add the correct dependency injection to any AngularJS files, as mentioned previously.
- Uglifyify: This will minify the file created by Browserify and ngAnnotate.
- Browser Sync: Full-featured development web server with livereload and devices sync
This generator also includes a simple framework for unit and end-to-end (e2e) testing via Karma and Jasmine. In order to test AngularJS modules, the angular.mocks module is used.
All of the tests can be run at once with the command gulp test
. However, the tests are broken up into two main categories:
MIT © Philipp Alferov