https://github.com/angular/angular
Raw File
Tip revision: ea3b5f1cde4ac30551898ada7b68d586be9f93ed authored by Andrew Kushnir on 10 May 2023, 18:18:44 UTC
release: cut the v16.1.0-next.0 release
Tip revision: ea3b5f1
README.md
# AIO project tooling

This document gives an overview of the tools that we use to generate the content for the angular.io website.

The application that actually renders this content can be found in the `/aio/src` folder.
The handwritten content can be found in the `/aio/content` folder.

Each subfolder in this `/aio/tools/` folder contains a self-contained tool and its configuration. There is
a `README.md` file in each folder that describes the tool in more detail.

## cli-patches

The AIO application is built using Angular Architect (backend for the Angular CLI tool) wrapped under Bazel. We are often trialling new features for Architect and CLI, which
we apply to the library after it is installed.  This folder contains git patch files that contain these new features
and a utility to apply those patches to the CLI library.

See the [README.md](cli-patches/README.md) for more details.

## examples

Many of the documentation pages contain snippets of code examples. We extract these snippets from real
working example applications, which are stored in subfolders of the `/aio/content/examples` folder. Each
example can be built and run independently. Each example also provides e2e specs, which are run as part
of our CI build tasks, to verify that the examples continue to work as expected, as changes are made
to the core Angular libraries.

There are a number of common boilerplate files that are needed to configure each
example's project. We maintain these common boilerplate files centrally to reduce the amount of effort
if one of them needs to change.

This `examples` tool folder contains three utilities:

* example-boilerplate.js - combine examples with the necessary boilerplate files. The compiled example
folder can be found in the Bazel output tree under `../dist/bin/aio/content/examples/my-example`.
* run-example-e2e.mjs - run the e2e tests for one or more examples
* create-example.js - create a new example from the `example-scaffold/` directory or by importing files from a CLI project.

See the [README.md](examples/README.md) for more details.

## example-zipper

In the AIO application, we offer the reader the option to download each example as a full self-contained runnable project packaged as a zip file.
These zip files are generated by the utility in this folder.

See the [README.md](example-zipper/README.md) for more details.

## stackblitz-builder

In the AIO application, we can embed a running version of the example as a [Stackblitz](https://stackblitz.com/) session.
We can also provide a link to create a runnable version of the example in the [Stackblitz](https://stackblitz.com/) editor.

See the [README.md](stackblitz-builder/README.md) for more details.

## transforms

All the content that is rendered by the AIO application, and some of its configuration files, are generated from source files by [Dgeni](https://github.com/angular/dgeni).
Dgeni is a general purpose documentation generation tool.

Markdown files in `/aio/content`, code comments in the core Angular source files and example files are processed and transformed into files that are consumed by the AIO application.

Dgeni is configured by "packages", which contain services and processors.
Some of these packages are installed as `node_modules` from the [dgeni-packages](https://github.com/angular/dgeni-packages) and some are specific to the AIO project.

The project specific packages are stored in the `aio/tools/transforms` folder.
See the [README.md](transforms/README.md) for more details.
back to top