2015-03-11 20:53:43 -04:00
# Angular.io
2016-06-28 22:37:28 -04:00
[![Build Status][travis-badge]][travis-badge-url]
2016-09-19 23:24:40 -04:00
Angular.io is site for Angular **documentation** .
2016-03-08 21:30:36 -05:00
This site also includes links to other helpful angular resources including
Angular 2, Angular 1, Angular Material, and AngularFire.
## Issues
2016-03-08 22:49:04 -05:00
Please file **Developer Guide, Cookbook, and code sample issues _only_** in this
2016-03-08 21:30:36 -05:00
[Angular.io ](https://github.com/angular/angular.io/issues ) github repo.
2016-03-08 22:49:04 -05:00
**Angular API issues, cheatsheet corrections, feature requests, defect reports, and technical questions** concerning Angular itself
2016-03-08 21:30:36 -05:00
belong in the [**angular source code** ](https://github.com/angular/angular/issues ) github repo.
We can't handle those topics here and will ask you to re-post them on the angular repo.
2015-03-11 20:53:43 -04:00
## How you can help
2016-03-08 21:30:36 -05:00
Filing issues is helpful but **pull requests** that improve the docs are even better!
Learn how to [contribute to Angular.io ](https://github.com/angular/angular.js/blob/master/CONTRIBUTING.md ).
2015-03-11 20:53:43 -04:00
2016-09-08 13:54:00 -04:00
> **IMPORTANT**: Do _NOT_ make changes to cached files under `public/docs/ts/_cache`. Cached files are updated through a separate workflow.
2016-09-08 13:52:54 -04:00
2015-03-11 20:53:43 -04:00
## Development Setup
2016-03-08 21:30:36 -05:00
This site relies heavily on node and npm.
2016-07-27 06:16:50 -04:00
1. Make sure you are using at least node v.5+ and latest npm;
2016-03-08 21:30:36 -05:00
if not install [nvm ](https://github.com/creationix/nvm ) to get node going on your machine.
2016-11-30 15:43:16 -05:00
1. Install global npm packages by running `./scripts/before-install.sh`
2016-03-08 21:30:36 -05:00
2016-11-30 15:43:16 -05:00
1. Clone
- this repo
- [angular/angular source code repo ](https://github.com/angular/angular )
2016-12-09 15:05:58 -05:00
to the same parent directory. The **cloned repo directories must be siblings** , with the latter named **angular** .
2016-03-08 21:30:36 -05:00
2016-05-25 11:30:43 -04:00
1. cd into root directory `angular.io/`
2016-03-08 21:30:36 -05:00
2016-11-30 15:43:16 -05:00
1. Install local npm packages by running `./scripts/install.sh`
2016-03-18 13:29:07 -04:00
1. See [below ](#code-sample-development ) for code sample development preparation.
2016-03-08 21:30:36 -05:00
## Content Development
All documentation content is written in Jade which has [its own syntax ](http://jade-lang.com/reference/ ).
Be aware of the strict demands imposed by this significant-whitespace language.
We strongly recommend running one of the gulp `serve-and-sync` commands [described below ](#serve-and-sync )
while editing content so you can see the effect of your changes *as you type* .
The documentation relies on specific styles and mixins.
2016-03-09 05:20:51 -05:00
Learn about those in the [documentation styleguide ](https://angular.io/docs/ts/latest/styleguide.html ).
2016-03-08 21:30:36 -05:00
The jade documentation files are language-specific directories under either `public/docs/` .
For example, all of the TypeScript docs are in `public/docs/ts/latest` , e.g.
- `public/docs/ts/latest/quickstart.jade`
- `public/docs/ts/latest/guide/architecture.jade`
- `public/docs/ts/latest/cookbook/component-communication.jade`
- `public/docs/ts/latest/tutorial/toh-pt5.jade`
### Local server with watches and browser reload
2016-05-25 11:30:43 -04:00
1. cd into root directory `angular.io/`
2016-03-08 21:30:36 -05:00
1. run `gulp serve-and-sync`
1. browser will launch on localhost:3000 and stay refreshed automatically.
< a id = "serve-and-sync" > < / a >
If you are only going to work on a specific part of the docs, such as the dev guide, then you can use one of the more specific gulp tasks to only watch those parts of the file system:
* `gulp serve-and-sync` : watch all the local Jade/Sass files, the API source and examples, and the dev guide files
2016-05-06 00:42:07 -04:00
* `gulp serve-and-sync-api` : watch only the API source and example files
2016-03-08 21:30:36 -05:00
* `gulp serve-and-sync-devguide` : watch only the dev guide files
* `gulp build-and-serve` : watch only the local Jade/Sass files
## Code Sample Development
All documentation is supported by sample code and plunkers.
2016-08-29 11:37:39 -04:00
Such code resides in the `public/docs/_examples` directory, under page-specific directories, further divided by language track.
2016-03-08 21:30:36 -05:00
For example, the TypeScript QuickStart sample is in `public/docs/_examples/quickstart/ts` .
2016-09-19 23:24:40 -04:00
All samples are in a consistent directory structure using the same styles and the same npm packages, including the latest release of Angular.
2016-03-08 21:30:36 -05:00
This consistency is possible in part thanks to gulp-driven tooling.
To run the samples locally and confirm that they work properly,
take the following extra steps to prepare the environment:
1. cd to `public/docs/_examples`
1. install the canonical node packages for all samples by running `npm install`
2016-05-25 11:30:43 -04:00
1. cd back up to `angular.io` root: `cd ../../..`
2016-03-08 21:30:36 -05:00
2016-03-18 13:29:07 -04:00
1. run `gulp add-example-boilerplate` (elevate to admin on Windows)
2016-10-20 20:01:16 -04:00
to copy canonical files to the sample directories and create symlinks there for node_modules.
2016-03-08 21:30:36 -05:00
Now cd into any particular sample's language directory (e.g., `public/docs/_examples/quickstart/ts` ) and try:
- `npm start` to simultaneously compile-with-watch and serve-in-browser-with-watch
- `npm run tsc` to compile only
- `npm run lite` to serve-and-watch in browser
Look at the scripts in `package.json` for other options.
Also, open any `plunkr.no-link.html` to see the code execute in plunker
(you may have to run `gulp build-plunkers` first to create/update).
2016-07-04 09:54:11 -04:00
You must check that your example is free of lint errors.
2016-06-19 05:09:07 -04:00
- `gulp lint`
2016-03-08 21:30:36 -05:00
### Sample end-to-end tests
2015-03-11 20:53:43 -04:00
2016-05-21 16:55:36 -04:00
All samples should be covered to some degree by end-to-end tests:
- `gulp run-e2e-tests` to run all TypeScript and JavaScript tests
2016-12-09 15:05:58 -05:00
- `gulp run-e2e-tests --lang=all` to run TypeScript and JavaScript tests
2016-05-21 16:55:36 -04:00
- `gulp run-e2e-tests --filter=quickstart` to filter the examples to run, by name
- `gulp run-e2e-tests --fast` to ignore npm install, webdriver update and boilerplate copy
Any combination of options is possible.
2015-11-13 11:54:46 -05:00
2016-07-04 09:54:11 -04:00
### Resetting the project
This project generates a lot of untracked files, if you wish to reset it to a mint state, you can run:
- `git clean -xdf`
2016-07-11 10:54:29 -04:00
Also, there is a script available for Linux, OSX and Windows Gitbash users that will setup the project using the steps shown in this section:
2016-07-04 09:54:11 -04:00
2016-07-15 20:13:48 -04:00
- `./scripts/install.sh`
2016-07-04 09:54:11 -04:00
2016-07-14 15:27:11 -04:00
### Run with current build instead of release packages
Can switch the `@angular` packages in `~/public/docs/_examples/node_modules` to the current build packages with
```
gulp install-example-angular --build
```
Restore to RELEASE packages with
```
gulp install-example-angular
```
>These commands will fail if something is locking any of the packages ... as an IDE often does.
>
>The symptom typically is an error trying to `rm -rf node_modules/@angular` .
>
>_Solution_: unlock the hold on the package(s). In VS Code, re-load the window (`cmd-P` then enter `>relow` ).
2015-11-13 11:54:46 -05:00
2015-03-11 20:53:43 -04:00
## Technology Used
- Angular 1.x: The production ready version of Angular
- Angular Material: An implementation of Material Design in Angular.js
2016-03-08 21:30:36 -05:00
- Gulp: node-based tooling
2015-03-11 20:53:43 -04:00
- Harp: The static web server with built-in preprocessing.
- Sass: A professional grade CSS extension language
- Normalize: A modern, HTML5-ready alternative to CSS resets
- Grids: A highly customizable CSS Grid Framework built with Sass
- Prettify: A JS module and CSS for syntax highlighting of source code snippets.
- Icomoon: Custom built icon fonts
## License
2016-03-08 21:30:36 -05:00
Powered by Google ©2010-2016. Code licensed under an [MIT-style License ](https://github.com/angular.io/blob/master/LICENSE ). Documentation licensed under [CC BY 4.0 ](http://creativecommons.org/licenses/by/4.0/ ).
2016-06-28 22:37:28 -04:00
[travis-badge]: https://travis-ci.org/angular/angular.io.svg?branch=master
[travis-badge-url]: https://travis-ci.org/angular/angular.io