Yeoman angular scaffolding for large projects
(will be building generator for angular 2.0 soon) This follows practice with Best Practice angular-styleguide/johnpapa. Quickly bootstrap angular projects and dev environment with the help of angular One. This is still in working progress for additional features.
Generator
- Builds skeleton (html,javascript, LESS, spec etc) for the component type.
- Update index.html and add the necessary
script
tags. - Update app.less and add the @import as needed.
- For partials, update the app.js, adding the necessary route call if a route was entered in the generator prompts.
Package manager (npm) need to be installed. You can get them from http://nodejs.org/.
npm install -g yo grunt-cli bower
npm install -g generator-angular-one
mkdir myNewproject
cd myNewproject
yo angular-one
Note: if EACCESS error , run bower and npm on sudo.
grunt serve
if you encountered error when 3rd party is installed library use reinstall manually bower and npm or use grunt serve --force,
generators for controller, directive, partial, service, filter, module, and modal.
yo angular-one:controller controllerName
yo angular-one:directive directiveName
yo angular-one:partial partialName
yo angular-one:service serviceName
yo angular-one:filter filterName
yo angular-one:module moduleName
yo angular-one:modal modalName
Name paramater passed will be used as the file names. Each sub-generator will ask for the folder in which to create the new skeleton files. You may override the default folder for each sub-generator in the `.yo-rc.json` file.
Modal subgenerator is a convenient shortcut to create partials that work as modals for Bootstrap v3.3.6 and Angular-UI-Bootstrap v0.10 (both come preconfigured with this generator). If you choose not to use either of these libraries, simply don't use the modal subgenerator.
Use the yo angular-one:module my-module
specify a new subdirectory to place the module into. Once you've created a submodule, running other subgenerators will now prompt you to select the module in which to place the new component.
Includes Angular 1.5, Bootstrap 3, AngularUI Bootstrap, AngularUI Utils, FontAwesome 4, JQuery 2, Underscore 1.5, LESS 2.6, and Moment 2.12. You may of course add to or remove any of these libraries. But the work to integrate them into the app and into the build process has already been done for you.
grunt test //karmajs testing
grunt build //dist folder
The project will include a ready-made Grunt build that will:
- Build all the LESS files into one minified CSS file.
- Uses grunt-angular-templates to turn all your partials into Javascript.
- Uses grunt-ng-annotate to preprocess all Angular injectable methods and make them minification safe. Thus you don't have to use the array syntax.
- Concatenates and minifies all Javascript into one file.
- Replaces all appropriate script references in
index.html
with the minified CSS and JS files. - (Optionally) Minifies any images in
/img
. - Minifies the
index.html
. - adds assets to dist
- Copies any extra files necessary for a distributable build (ex. Font-Awesome font files, etc).
The resulting build loads only a few highly compressed files.
The build process uses grunt-dom-munger to pull script references from the index.html
. This means that your index.html is the single source of truth about what makes up your app. Adding a new library, new controller, new directive, etc does not require that you update the build file. Also the order of the scripts in your index.html
will be maintained when they're concatenated.
Importantly, grunt-dom-munger uses CSS attribute selectors to manage the parsing of the script and link tags. Its very easy to exclude certain scripts or stylesheets from the concatenated files. This is often the case if you're using a CDN. This can also be used to prevent certain development scripts from being included in the final build.
-
To prevent a script or stylesheet from being included in concatenation, put a
data-concat="false"
attribute on the link or script tag. This is currently applied for thelivereload.js
andless.js
script tags. -
To prevent a script or link tag from being removed from the finalized
index.html
, use adata-remove="false"
attribute.