UNPKG

angular-cli-builders

Version:
153 lines (129 loc) 8.14 kB
# angular-cli-builders [![npm version](https://badge.fury.io/js/angular-cli-builders.svg)](https://badge.fury.io/js/angular-cli-builders) [![Build Status](https://travis-ci.org/meltedspark/angular-cli-builders.svg?branch=master)](https://travis-ci.org/meltedspark/angular-cli-builders) [![Greenkeeper badge](https://badges.greenkeeper.io/meltedspark/angular-cli-builders.svg)](https://greenkeeper.io/) A set of additional [builders](#builders) for Angular CLI. Allows customizing the build configuration without ejecting webpack configuration (`ng eject`) # Prerequisites: - [Angular CLI 6](https://www.npmjs.com/package/@angular/cli) - [@angular-devkit/architect](https://www.npmjs.com/package/@angular-devkit/architect) >= 0.7.0 - [@angular-devkit/build-angular](https://npmjs.com/package/@angular-devkit/build-angular) >= 0.7.0 - [@angular-devkit/core](https://npmjs.com/package/@angular-devkit/core) >= 0.7.0 # Usage 1. ```npm i -D angular-cli-builders``` 2. In your `angular.json`: ``` ... "architect": { ... "[architect-target]": { "builder": "angular-cli-builders:[name-of-builder]" "options": { ... } ``` Where: - [architect-target] is the name of build target you want to run (build, serve, test etc.) - [name-of-builder] one of the supported builders (specified below) 3. `ng [architect-target]` ## For example - angular.json: ``` "architect": { ... "build": { "builder": "angular-builders:custom-webpack-browser" "options": { ... } ``` - Run the build: `ng build` # Builders - [custom-webpack-browser](#custom-webpack-browser) - [custom-webpack-server](#custom-webpack-server) - [generic-dev-server](#generic-dev-server) ## custom-webpack-browser Extended `@angular-devkit/build-angular:browser` builder that allows to specify additional webpack configuration (on top of the existing under the hood). The builder will run the same build as `@angular-devkit/build-angular:browser` does with extra parameters that are specified in the provided webpack configuration. Options: - All the `@angular-devkit/build-angular:browser` options - `customWebpackConfig`: configuration object with the following properties: - `path`: path to the extra webpack configuration, defaults to `webpack.config.js` - `mergeStrategies`: webpack config merge strategies, can be `append | prepend | replace` per webpack config entry. Defaults to `append`. - `append`: appends the given entry configuration (in custom webpack config) to the existing Angular CLI webpack configuration. - `prepend`: prepends the given entry configuration (in custom webpack config) to the existing field configuration (in Angular CLI webpack config). The custom loaders config will be added to the _beginning_ of the existing loaders array. - `replace`: replaces the given entry configuration entirely. The custom webpack config will replace the Angular CLI webpack config (for this particular entry). See [webpack-merge](https://github.com/survivejs/webpack-merge) for more info. - `replaceDuplicatePlugins`: Defaults to `false`. If `true`, the plugins in custom webpack config will replace the corresponding plugins in default Angular CLI webpack configuration. `angular.json` Example: ``` "architect": { ... "build": { "builder": "angular-cli-builders:custom-webpack-browser" "options": { "customWebpackConfig": { path: "./extra-webpack.config.js", mergeStrategies: { "externals": "prepend" }, } "outputPath": "dist/my-cool-client", "index": "src/index.html", "main": "src/main.ts", "polyfills": "src/polyfills.ts", "tsConfig": "src/tsconfig.app.json" } ``` In this example `externals` entry from `extra-webpack.config.js` will be prepended to `externals` entry from Angular CLI underlying webpack config. ## custom-webpack-server Extended `@angular-devkit/build-angular:server` builder that allows to specify additional webpack configuration (on top of the existing under the hood). The builder will run the same build as `@angular-devkit/build-angular:server` does with extra parameters that are specified in the provided webpack configuration. Options: - All the `@angular-devkit/build-angular:server` options - `customWebpackConfig`: configuration object with the following properties: - `path`: path to the extra webpack configuration, defaults to `webpack.config.js` - `mergeStrategies`: webpack config merge strategies, can be `append | prepend | replace` per webpack config entry. Defaults to `append`. - `append`: appends the given entry configuration (in custom webpack config) to the existing Angular CLI webpack configuration. - `prepend`: prepends the given entry configuration (in custom webpack config) to the existing field configuration (in Angular CLI webpack config). The custom loaders config will be added to the _beginning_ of the existing loaders array. - `replace`: replaces the given entry configuration entirely. The custom webpack config will replace the Angular CLI webpack config (for this particular entry). See [webpack-merge](https://github.com/survivejs/webpack-merge) for more info. - `replaceDuplicatePlugins`: Defaults to `false`. If `true`, the plugins in custom webpack config will replace the corresponding plugins in default Angular CLI webpack configuration. `angular.json` Example: ``` "architect": { ... "build": { "builder": "angular-cli-builders:custom-webpack-server" "options": { "customWebpackConfig": { path: "./extra-webpack.config.js", mergeStrategies: { "loaders": "replace" }, replaceDuplicatePlugins: true } "outputPath": "dist/my-cool-server", "main": "src/main.server.ts", "tsConfig": "src/tsconfig.server.json" } ``` In this example `loaders` entry from Angular CLI webpack config will be _replaced_ with loaders entry from `extra-webpack.config.js`. The plugins from `extra-webpack.config.js` will override the corresponding plugins from Angular CLI webpack config. ## generic-dev-server Enhanced `@angular-devkit/build-angular:dev-server` builder that leverages the custom webpack builder to get webpack configuration. Unlike the default `@angular-devkit/build-angular:dev-server` it doesn't use `@angular-devkit/build-angular:browser` configuration to run the dev server. Instead it uses a builder that is specified in `browserTarget` _as long as it provides `buildWebpackConfig` method_. Thus, if you use `generic-dev-server` along with `custom-webpack-browser`, `ng serve` will run with custom configuration provided in the latter. `angular.json` Example ``` "architect": { ... "build": { "builder": "angular-cli-builders:custom-webpack-browser" "options": { "webpackConfigPath": "./extra-webpack.config.js", "mergeStrategy": { "loaders": "replace" }, ... }, "serve": { "builder": "angular-cli-builders:generic-dev-server", "options": { "browserTarget": "my-project:build" } } ``` In this example the dev-server will use the webpack builder from the custom-webpack-browser when invoking the serve target. # Further reading - [Customizing Angular CLI 6 build  -  an alternative to ng eject](https://medium.com/@meltedspark/customizing-angular-cli-6-build-an-alternative-to-ng-eject-a48304cd3b21)