@angular-devkit/build-angular 0.7.1 → 0.7.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (77) hide show
  1. package/package.json +10 -8
  2. package/plugins/karma.d.ts +7 -0
  3. package/src/angular-cli-files/lib/base-href-webpack/base-href-webpack-plugin.js +1 -1
  4. package/src/angular-cli-files/models/webpack-configs/browser.d.ts +7 -0
  5. package/src/angular-cli-files/models/webpack-configs/browser.js +1 -1
  6. package/src/angular-cli-files/models/webpack-configs/common.d.ts +7 -0
  7. package/src/angular-cli-files/models/webpack-configs/common.js +1 -1
  8. package/src/angular-cli-files/models/webpack-configs/server.js +1 -1
  9. package/src/angular-cli-files/models/webpack-configs/stats.js +1 -1
  10. package/src/angular-cli-files/models/webpack-configs/styles.d.ts +0 -3
  11. package/src/angular-cli-files/models/webpack-configs/styles.js +6 -8
  12. package/src/angular-cli-files/models/webpack-configs/test.d.ts +7 -0
  13. package/src/angular-cli-files/models/webpack-configs/test.js +6 -2
  14. package/src/angular-cli-files/models/webpack-configs/typescript.js +1 -1
  15. package/src/angular-cli-files/models/webpack-configs/utils.d.ts +7 -0
  16. package/src/angular-cli-files/models/webpack-configs/utils.js +1 -1
  17. package/src/angular-cli-files/plugins/bundle-budget.d.ts +3 -3
  18. package/src/angular-cli-files/plugins/bundle-budget.js +1 -1
  19. package/src/angular-cli-files/plugins/cleancss-webpack-plugin.js +2 -2
  20. package/src/angular-cli-files/plugins/index-html-webpack-plugin.d.ts +1 -1
  21. package/src/angular-cli-files/plugins/index-html-webpack-plugin.js +1 -1
  22. package/src/angular-cli-files/plugins/karma-webpack-failure-cb.js +1 -1
  23. package/src/angular-cli-files/plugins/karma.d.ts +7 -0
  24. package/src/angular-cli-files/plugins/karma.js +29 -16
  25. package/src/angular-cli-files/plugins/postcss-cli-resources.js +1 -1
  26. package/src/angular-cli-files/plugins/raw-css-loader.js +2 -2
  27. package/src/angular-cli-files/plugins/remove-hash-plugin.d.ts +1 -1
  28. package/src/angular-cli-files/plugins/remove-hash-plugin.js +6 -5
  29. package/src/angular-cli-files/plugins/scripts-webpack-plugin.d.ts +1 -1
  30. package/src/angular-cli-files/plugins/scripts-webpack-plugin.js +1 -1
  31. package/src/angular-cli-files/plugins/suppress-entry-chunks-webpack-plugin.js +1 -1
  32. package/src/angular-cli-files/plugins/webpack.d.ts +1 -1
  33. package/src/angular-cli-files/utilities/bundle-calculator.js +2 -2
  34. package/src/angular-cli-files/utilities/check-port.js +1 -1
  35. package/src/angular-cli-files/utilities/find-up.d.ts +7 -0
  36. package/src/angular-cli-files/utilities/find-up.js +1 -1
  37. package/src/angular-cli-files/utilities/is-directory.d.ts +7 -0
  38. package/src/angular-cli-files/utilities/is-directory.js +1 -1
  39. package/src/angular-cli-files/utilities/package-chunk-sort.d.ts +7 -0
  40. package/src/angular-cli-files/utilities/package-chunk-sort.js +1 -1
  41. package/src/angular-cli-files/utilities/read-tsconfig.js +1 -1
  42. package/src/angular-cli-files/utilities/require-project-module.js +1 -1
  43. package/src/angular-cli-files/utilities/service-worker/index.js +5 -6
  44. package/src/angular-cli-files/utilities/stats.js +1 -1
  45. package/src/angular-cli-files/utilities/strip-bom.js +1 -1
  46. package/src/app-shell/index.d.ts +2 -1
  47. package/src/app-shell/index.js +21 -7
  48. package/src/browser/index.d.ts +1 -1
  49. package/src/browser/index.js +6 -5
  50. package/src/browser/schema.d.ts +2 -2
  51. package/src/browser/schema.json +2 -3
  52. package/src/dev-server/index.d.ts +9 -8
  53. package/src/dev-server/index.js +6 -5
  54. package/src/dev-server/schema.json +1 -1
  55. package/src/extract-i18n/index.js +1 -1
  56. package/src/karma/index.d.ts +1 -1
  57. package/src/karma/index.js +2 -1
  58. package/src/karma/schema.json +1 -2
  59. package/src/protractor/index.d.ts +3 -3
  60. package/src/protractor/index.js +1 -1
  61. package/src/server/index.d.ts +2 -2
  62. package/src/server/index.js +2 -1
  63. package/src/server/schema.d.ts +1 -1
  64. package/src/server/schema.json +2 -3
  65. package/src/tslint/index.d.ts +1 -1
  66. package/src/tslint/index.js +11 -5
  67. package/src/utils/default-progress.d.ts +8 -0
  68. package/src/utils/default-progress.js +17 -0
  69. package/src/utils/index.d.ts +1 -0
  70. package/src/utils/index.js +2 -1
  71. package/src/utils/normalize-asset-patterns.js +1 -1
  72. package/src/utils/normalize-file-replacements.js +1 -1
  73. package/src/utils/run-module-as-observable-fork.js +1 -1
  74. package/src/utils/run-module-worker.js +1 -1
  75. package/src/utils/webpack-file-system-host-adapter.d.ts +1 -1
  76. package/src/utils/webpack-file-system-host-adapter.js +1 -1
  77. package/test/utils.d.ts +1 -3
@@ -71,4 +71,4 @@ function statsErrorsToString(json, statsConfig) {
71
71
  return rs('\n' + json.errors.map((error) => r(`ERROR in ${error}`)).join('\n'));
72
72
  }
73
73
  exports.statsErrorsToString = statsErrorsToString;
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stats.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/angular-cli-files/utilities/stats.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n// tslint:disable\n// TODO: cleanup this file, it's copied as is from Angular CLI.\nimport { tags, terminal } from '@angular-devkit/core';\n\n\nconst { bold, green, red, reset, white, yellow } = terminal;\n\nexport function formatSize(size: number): string {\n  if (size <= 0) {\n    return '0 bytes';\n  }\n\n  const abbreviations = ['bytes', 'kB', 'MB', 'GB'];\n  const index = Math.floor(Math.log(size) / Math.log(1000));\n\n  return `${+(size / Math.pow(1000, index)).toPrecision(3)} ${abbreviations[index]}`;\n}\n\n\nexport function statsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const w = (x: string) => colors ? bold(white(x)) : x;\n  const g = (x: string) => colors ? bold(green(x)) : x;\n  const y = (x: string) => colors ? bold(yellow(x)) : x;\n\n  const changedChunksStats = json.chunks\n    .filter((chunk: any) => chunk.rendered)\n    .map((chunk: any) => {\n      const asset = json.assets.filter((x: any) => x.name == chunk.files[0])[0];\n      const size = asset ? ` ${formatSize(asset.size)}` : '';\n      const files = chunk.files.join(', ');\n      const names = chunk.names ? ` (${chunk.names.join(', ')})` : '';\n      const initial = y(chunk.entry ? '[entry]' : chunk.initial ? '[initial]' : '');\n      const flags = ['rendered', 'recorded']\n        .map(f => f && chunk[f] ? g(` [${f}]`) : '')\n        .join('');\n\n      return `chunk {${y(chunk.id)}} ${g(files)}${names}${size} ${initial}${flags}`;\n    });\n\n  const unchangedChunkNumber = json.chunks.length - changedChunksStats.length;\n\n  if (unchangedChunkNumber > 0) {\n    return '\\n' + rs(tags.stripIndents`\n      Date: ${w(new Date().toISOString())} - Hash: ${w(json.hash)} - Time: ${w('' + json.time)}ms\n      ${unchangedChunkNumber} unchanged chunks\n      ${changedChunksStats.join('\\n')}\n      `);\n  } else {\n    return '\\n' + rs(tags.stripIndents`\n      Date: ${w(new Date().toISOString())}\n      Hash: ${w(json.hash)}\n      Time: ${w('' + json.time)}ms\n      ${changedChunksStats.join('\\n')}\n      `);\n  }\n}\n\nexport function statsWarningsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const y = (x: string) => colors ? bold(yellow(x)) : x;\n\n  return rs('\\n' + json.warnings.map((warning: any) => y(`WARNING in ${warning}`)).join('\\n\\n'));\n}\n\nexport function statsErrorsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const r = (x: string) => colors ? bold(red(x)) : x;\n\n  return rs('\\n' + json.errors.map((error: any) => r(`ERROR in ${error}`)).join('\\n'));\n}\n"]}
74
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stats.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/angular-cli-files/utilities/stats.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n// tslint:disable\n// TODO: cleanup this file, it's copied as is from Angular CLI.\nimport { tags, terminal } from '@angular-devkit/core';\n\n\nconst { bold, green, red, reset, white, yellow } = terminal;\n\nexport function formatSize(size: number): string {\n  if (size <= 0) {\n    return '0 bytes';\n  }\n\n  const abbreviations = ['bytes', 'kB', 'MB', 'GB'];\n  const index = Math.floor(Math.log(size) / Math.log(1000));\n\n  return `${+(size / Math.pow(1000, index)).toPrecision(3)} ${abbreviations[index]}`;\n}\n\n\nexport function statsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const w = (x: string) => colors ? bold(white(x)) : x;\n  const g = (x: string) => colors ? bold(green(x)) : x;\n  const y = (x: string) => colors ? bold(yellow(x)) : x;\n\n  const changedChunksStats = json.chunks\n    .filter((chunk: any) => chunk.rendered)\n    .map((chunk: any) => {\n      const asset = json.assets.filter((x: any) => x.name == chunk.files[0])[0];\n      const size = asset ? ` ${formatSize(asset.size)}` : '';\n      const files = chunk.files.join(', ');\n      const names = chunk.names ? ` (${chunk.names.join(', ')})` : '';\n      const initial = y(chunk.entry ? '[entry]' : chunk.initial ? '[initial]' : '');\n      const flags = ['rendered', 'recorded']\n        .map(f => f && chunk[f] ? g(` [${f}]`) : '')\n        .join('');\n\n      return `chunk {${y(chunk.id)}} ${g(files)}${names}${size} ${initial}${flags}`;\n    });\n\n  const unchangedChunkNumber = json.chunks.length - changedChunksStats.length;\n\n  if (unchangedChunkNumber > 0) {\n    return '\\n' + rs(tags.stripIndents`\n      Date: ${w(new Date().toISOString())} - Hash: ${w(json.hash)} - Time: ${w('' + json.time)}ms\n      ${unchangedChunkNumber} unchanged chunks\n      ${changedChunksStats.join('\\n')}\n      `);\n  } else {\n    return '\\n' + rs(tags.stripIndents`\n      Date: ${w(new Date().toISOString())}\n      Hash: ${w(json.hash)}\n      Time: ${w('' + json.time)}ms\n      ${changedChunksStats.join('\\n')}\n      `);\n  }\n}\n\nexport function statsWarningsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const y = (x: string) => colors ? bold(yellow(x)) : x;\n\n  return rs('\\n' + json.warnings.map((warning: any) => y(`WARNING in ${warning}`)).join('\\n\\n'));\n}\n\nexport function statsErrorsToString(json: any, statsConfig: any) {\n  const colors = statsConfig.colors;\n  const rs = (x: string) => colors ? reset(x) : x;\n  const r = (x: string) => colors ? bold(red(x)) : x;\n\n  return rs('\\n' + json.errors.map((error: any) => r(`ERROR in ${error}`)).join('\\n'));\n}\n"]}
@@ -15,4 +15,4 @@ function stripBom(data) {
15
15
  return data.replace(/^\uFEFF/, '');
16
16
  }
17
17
  exports.stripBom = stripBom;
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaXAtYm9tLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy9hbmd1bGFyLWNsaS1maWxlcy91dGlsaXRpZXMvc3RyaXAtYm9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7QUFDSCxpQkFBaUI7QUFDakIsK0RBQStEOztBQUUvRCw0QkFBNEI7QUFDNUIsK0NBQStDO0FBQy9DLGtCQUF5QixJQUFZO0lBQ25DLE1BQU0sQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQUMsQ0FBQztBQUNyQyxDQUFDO0FBRkQsNEJBRUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG4vLyB0c2xpbnQ6ZGlzYWJsZVxuLy8gVE9ETzogY2xlYW51cCB0aGlzIGZpbGUsIGl0J3MgY29waWVkIGFzIGlzIGZyb20gQW5ndWxhciBDTEkuXG5cbi8vIFN0cmlwIEJPTSBmcm9tIGZpbGUgZGF0YS5cbi8vIGh0dHBzOi8vc3RhY2tvdmVyZmxvdy5jb20vcXVlc3Rpb25zLzI0MzU2NzEzXG5leHBvcnQgZnVuY3Rpb24gc3RyaXBCb20oZGF0YTogc3RyaW5nKSB7XG4gIHJldHVybiBkYXRhLnJlcGxhY2UoL15cXHVGRUZGLywgJycpO1xufVxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RyaXAtYm9tLmpzIiwic291cmNlUm9vdCI6Ii4vIiwic291cmNlcyI6WyJwYWNrYWdlcy9hbmd1bGFyX2RldmtpdC9idWlsZF9hbmd1bGFyL3NyYy9hbmd1bGFyLWNsaS1maWxlcy91dGlsaXRpZXMvc3RyaXAtYm9tLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7O0dBTUc7QUFDSCxpQkFBaUI7QUFDakIsK0RBQStEOztBQUUvRCw0QkFBNEI7QUFDNUIsK0NBQStDO0FBQy9DLGtCQUF5QixJQUFZO0lBQ25DLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxTQUFTLEVBQUUsRUFBRSxDQUFDLENBQUM7QUFDckMsQ0FBQztBQUZELDRCQUVDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBJbmMuIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuLy8gdHNsaW50OmRpc2FibGVcbi8vIFRPRE86IGNsZWFudXAgdGhpcyBmaWxlLCBpdCdzIGNvcGllZCBhcyBpcyBmcm9tIEFuZ3VsYXIgQ0xJLlxuXG4vLyBTdHJpcCBCT00gZnJvbSBmaWxlIGRhdGEuXG4vLyBodHRwczovL3N0YWNrb3ZlcmZsb3cuY29tL3F1ZXN0aW9ucy8yNDM1NjcxM1xuZXhwb3J0IGZ1bmN0aW9uIHN0cmlwQm9tKGRhdGE6IHN0cmluZykge1xuICByZXR1cm4gZGF0YS5yZXBsYWNlKC9eXFx1RkVGRi8sICcnKTtcbn1cbiJdfQ==
@@ -8,6 +8,7 @@
8
8
  import { BuildEvent, Builder, BuilderConfiguration, BuilderContext } from '@angular-devkit/architect';
9
9
  import { Path } from '@angular-devkit/core';
10
10
  import { Observable } from 'rxjs';
11
+ import { BrowserBuilderSchema } from '../browser/schema';
11
12
  import { BuildWebpackAppShellSchema } from './schema';
12
13
  export declare class AppShellBuilder implements Builder<BuildWebpackAppShellSchema> {
13
14
  context: BuilderContext;
@@ -15,7 +16,7 @@ export declare class AppShellBuilder implements Builder<BuildWebpackAppShellSche
15
16
  run(builderConfig: BuilderConfiguration<BuildWebpackAppShellSchema>): Observable<BuildEvent>;
16
17
  build(targetString: string, overrides: {}): Observable<BuildEvent>;
17
18
  getServerModuleBundlePath(options: BuildWebpackAppShellSchema): Observable<Path>;
18
- getBrowserIndexOutputPath(options: BuildWebpackAppShellSchema): Observable<Path>;
19
+ getBrowserBuilderConfig(options: BuildWebpackAppShellSchema): Observable<BuilderConfiguration<BrowserBuilderSchema>>;
19
20
  renderUniversal(options: BuildWebpackAppShellSchema): Observable<BuildEvent>;
20
21
  }
21
22
  export default AppShellBuilder;
@@ -4,6 +4,7 @@ const core_1 = require("@angular-devkit/core");
4
4
  const rxjs_1 = require("rxjs");
5
5
  const operators_1 = require("rxjs/operators");
6
6
  const require_project_module_1 = require("../angular-cli-files/utilities/require-project-module");
7
+ const service_worker_1 = require("../angular-cli-files/utilities/service-worker");
7
8
  class AppShellBuilder {
8
9
  constructor(context) {
9
10
  this.context = context;
@@ -12,7 +13,10 @@ class AppShellBuilder {
12
13
  const options = builderConfig.options;
13
14
  return new rxjs_1.Observable(obs => {
14
15
  let success = true;
15
- const subscription = rxjs_1.merge(this.build(options.serverTarget, {}), this.build(options.browserTarget, { watch: false })).subscribe((event) => {
16
+ const subscription = rxjs_1.merge(this.build(options.serverTarget, {}),
17
+ // Never run the browser target in watch mode.
18
+ // If service worker is needed, it will be added in this.renderUniversal();
19
+ this.build(options.browserTarget, { watch: false, serviceWorker: false })).subscribe((event) => {
16
20
  // TODO: once we support a better build event, add support for merging two event streams
17
21
  // together.
18
22
  success = success && event.success;
@@ -73,7 +77,7 @@ class AppShellBuilder {
73
77
  }
74
78
  });
75
79
  }
76
- getBrowserIndexOutputPath(options) {
80
+ getBrowserBuilderConfig(options) {
77
81
  const architect = this.context.architect;
78
82
  const [project, target, configuration] = options.browserTarget.split(':');
79
83
  const builderConfig = architect.getBuilderConfiguration({
@@ -81,10 +85,15 @@ class AppShellBuilder {
81
85
  target,
82
86
  configuration,
83
87
  });
84
- return architect.getBuilderDescription(builderConfig).pipe(operators_1.concatMap(description => architect.validateBuilderOptions(builderConfig, description)), operators_1.map(config => core_1.join(core_1.normalize(config.options.outputPath), 'index.html')));
88
+ return architect.getBuilderDescription(builderConfig).pipe(operators_1.concatMap(description => architect.validateBuilderOptions(builderConfig, description)));
85
89
  }
86
90
  renderUniversal(options) {
87
- return rxjs_1.forkJoin(this.getBrowserIndexOutputPath(options).pipe(operators_1.switchMap(browserIndexOutputPath => {
91
+ let browserOptions;
92
+ let projectRoot;
93
+ return rxjs_1.forkJoin(this.getBrowserBuilderConfig(options).pipe(operators_1.switchMap(config => {
94
+ browserOptions = config.options;
95
+ projectRoot = core_1.resolve(this.context.workspace.root, config.root);
96
+ const browserIndexOutputPath = core_1.join(core_1.normalize(browserOptions.outputPath), 'index.html');
88
97
  const path = core_1.join(this.context.workspace.root, browserIndexOutputPath);
89
98
  return this.context.host.read(path).pipe(operators_1.map(x => {
90
99
  return [browserIndexOutputPath, x];
@@ -95,7 +104,7 @@ class AppShellBuilder {
95
104
  const renderModuleFactory = require_project_module_1.requireProjectModule(core_1.getSystemPath(root), '@angular/platform-server').renderModuleFactory;
96
105
  const AppServerModuleNgFactory = require(core_1.getSystemPath(serverBundlePath)).AppServerModuleNgFactory;
97
106
  const indexHtml = core_1.virtualFs.fileBufferToString(indexContent);
98
- const outputPath = core_1.join(root, options.outputIndexPath || browserIndexOutputPath);
107
+ const outputIndexPath = core_1.join(root, options.outputIndexPath || browserIndexOutputPath);
99
108
  // Render to HTML and overwrite the client index file.
100
109
  return rxjs_1.from(renderModuleFactory(AppServerModuleNgFactory, {
101
110
  document: indexHtml,
@@ -103,8 +112,13 @@ class AppShellBuilder {
103
112
  })
104
113
  .then((html) => {
105
114
  return this.context.host
106
- .write(outputPath, core_1.virtualFs.stringToFileBuffer(html))
115
+ .write(outputIndexPath, core_1.virtualFs.stringToFileBuffer(html))
107
116
  .toPromise();
117
+ })
118
+ .then(() => {
119
+ if (browserOptions.serviceWorker) {
120
+ return service_worker_1.augmentAppWithServiceWorker(this.context.host, root, projectRoot, core_1.join(root, browserOptions.outputPath), browserOptions.baseHref || '/', browserOptions.ngswConfigPath);
121
+ }
108
122
  })
109
123
  .then(() => ({ success: true })));
110
124
  }));
@@ -112,4 +126,4 @@ class AppShellBuilder {
112
126
  }
113
127
  exports.AppShellBuilder = AppShellBuilder;
114
128
  exports.default = AppShellBuilder;
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/app-shell/index.ts"],"names":[],"mappings":";;AAaA,+CAAuF;AACvF,+BAAyE;AACzE,8CAA2D;AAC3D,kGAA6F;AAK7F;IAEE,YAAmB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;IAAI,CAAC;IAE/C,GAAG,CAAC,aAA+D;QACjE,MAAM,OAAO,GAAG,aAAa,CAAC,OAAO,CAAC;QAEtC,MAAM,CAAC,IAAI,iBAAU,CAAa,GAAG,CAAC,EAAE;YACtC,IAAI,OAAO,GAAG,IAAI,CAAC;YACnB,MAAM,YAAY,GAAG,YAAK,CACxB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,EACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CACpD,CAAC,SAAS,CAAC,CAAC,KAAiB,EAAE,EAAE;gBAChC,wFAAwF;gBACxF,YAAY;gBACZ,OAAO,GAAG,OAAO,IAAI,KAAK,CAAC,OAAO,CAAC;YACrC,CAAC,EAAE,KAAK,CAAC,EAAE;gBACT,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YACnB,CAAC,EAAE,GAAG,EAAE;gBACN,GAAG,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;gBACtB,GAAG,CAAC,QAAQ,EAAE,CAAC;YACjB,CAAC,CAAC,CAAC;YAEH,8EAA8E;YAC9E,MAAM,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAC1C,CAAC,CAAC,CAAC,IAAI,CACL,qBAAS,CAAC,KAAK,CAAC,EAAE;YAChB,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;gBACnB,MAAM,CAAC,SAAE,CAAC,KAAK,CAAC,CAAC;YACnB,CAAC;YAED,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,CAAC;QACvC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,YAAoB,EAAE,SAAa;QACvC,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QACzC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,GAAG,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAEjE,wCAAwC;QACxC,MAAM,aAAa,GAAG,SAAS,CAAC,uBAAuB,CAAK;YAC1D,OAAO;YACP,MAAM;YACN,aAAa;YACb,SAAS;SACV,CAAC,CAAC;QAEH,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,yBAAyB,CAAC,OAAmC;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QAEzC,MAAM,CAAC,IAAI,iBAAU,CAAO,GAAG,CAAC,EAAE;YAChC,EAAE,CAAC,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;gBAC5B,GAAG,CAAC,IAAI,CAAC,WAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;gBAErE,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YACxB,CAAC;YAAC,IAAI,CAAC,CAAC;gBACN,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,GAAG,OAAO,CAAC,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;gBACzE,MAAM,aAAa,GAAG,SAAS,CAAC,uBAAuB,CAA2B;oBAChF,OAAO;oBACP,MAAM;oBACN,aAAa;iBACd,CAAC,CAAC;gBAEH,MAAM,CAAC,SAAS,CAAC,qBAAqB,CAAC,aAAa,CAAC,CAAC,IAAI,CACxD,qBAAS,CAAC,WAAW,CAAC,EAAE,CAAC,SAAS,CAAC,sBAAsB,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC,EACtF,qBAAS,CAAC,MAAM,CAAC,EAAE;oBACjB,MAAM,UAAU,GAAG,WAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;oBAEhF,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAC5C,qBAAS,CAAC,KAAK,CAAC,EAAE;wBAChB,MAAM,EAAE,GAAG,+CAA+C,CAAC;wBAC3D,MAAM,SAAS,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;wBAEnD,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;4BACf,MAAM,CAAC,iBAAU,CAAC,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC,CAAC;wBAClE,CAAC;wBAAC,IAAI,CAAC,CAAC;4BACN,MAAM,CAAC,SAAE,CAAC,WAAI,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;wBACzC,CAAC;oBACH,CAAC,CAAC,CACH,CAAC;gBACJ,CAAC,CAAC,CACH,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;YACnB,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,yBAAyB,CAAC,OAAmC;QAC3D,MAAM,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;QACzC,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,aAAa,CAAC,GAAG,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC1E,MAAM,aAAa,GAAG,SAAS,CAAC,uBAAuB,CAA2B;YAChF,OAAO;YACP,MAAM;YACN,aAAa;SACd,CAAC,CAAC;QAEH,MAAM,CAAC,SAAS,CAAC,qBAAqB,CAAC,aAAa,CAAC,CAAC,IAAI,CACxD,qBAAS,CAAC,WAAW,CAAC,EAAE,CAAC,SAAS,CAAC,sBAAsB,CAAC,aAAa,EAAE,WAAW,CAAC,CAAC,EACtF,eAAG,CAAC,MAAM,CAAC,EAAE,CAAC,WAAI,CAAC,gBAAS,CAAC,MAAM,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE,YAAY,CAAC,CAAC,CACxE,CAAC;IACJ,CAAC;IAED,eAAe,CAAC,OAAmC;QACjD,MAAM,CAAC,eAAQ,CACb,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CAAC,IAAI,CAC1C,qBAAS,CAAC,sBAAsB,CAAC,EAAE;YACjC,MAAM,IAAI,GAAG,WAAI,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,EAAE,sBAAsB,CAAC,CAAC;YAEvE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CACtC,eAAG,CAAqD,CAAC,CAAC,EAAE;gBAC1D,MAAM,CAAC,CAAC,sBAAsB,EAAE,CAAC,CAAC,CAAC;YACrC,CAAC,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CACH,EACD,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,CACxC,CAAC,IAAI,CACJ,qBAAS,CAAC,CAAC,CAAC,CAAC,sBAAsB,EAAE,YAAY,CAAC,EAAE,gBAAgB,CAAC,EAAE,EAAE;YACvE,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC;YACzC,6CAAoB,CAAC,oBAAa,CAAC,IAAI,CAAC,EAAE,wBAAwB,CAAC,CAAC;YAEpE,MAAM,mBAAmB,GAAG,6CAAoB,CAC9C,oBAAa,CAAC,IAAI,CAAC,EACnB,0BAA0B,CAC3B,CAAC,mBAAmB,CAAC;YACtB,MAAM,wBAAwB,GAAG,OAAO,CACtC,oBAAa,CAAC,gBAAgB,CAAC,CAChC,CAAC,wBAAwB,CAAC;YAC3B,MAAM,SAAS,GAAG,gBAAS,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;YAC7D,MAAM,UAAU,GAAG,WAAI,CAAC,IAAI,EAAE,OAAO,CAAC,eAAe,IAAI,sBAAsB,CAAC,CAAC;YAEjF,sDAAsD;YACtD,MAAM,CAAC,WAAI,CACT,mBAAmB,CAAC,wBAAwB,EAAE;gBAC5C,QAAQ,EAAE,SAAS;gBACnB,GAAG,EAAE,OAAO,CAAC,KAAK;aACnB,CAAC;iBACD,IAAI,CAAC,CAAC,IAAY,EAAE,EAAE;gBACrB,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI;qBACrB,KAAK,CAAC,UAAU,EAAE,gBAAS,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;qBACrD,SAAS,EAAE,CAAC;YACjB,CAAC,CAAC;iBACD,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CACjC,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CACF;AAtJD,0CAsJC;AAED,kBAAe,eAAe,CAAC","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { Path, getSystemPath, join, normalize, virtualFs } from '@angular-devkit/core';\nimport { Observable, forkJoin, from, merge, of, throwError } from 'rxjs';\nimport { concatMap, map, switchMap } from 'rxjs/operators';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { BuildWebpackServerSchema } from '../server/schema';\nimport { BuildWebpackAppShellSchema } from './schema';\n\n\nexport class AppShellBuilder implements Builder<BuildWebpackAppShellSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BuildWebpackAppShellSchema>): Observable<BuildEvent> {\n    const options = builderConfig.options;\n\n    return new Observable<BuildEvent>(obs => {\n      let success = true;\n      const subscription = merge(\n        this.build(options.serverTarget, {}),\n        this.build(options.browserTarget, { watch: false }),\n      ).subscribe((event: BuildEvent) => {\n        // TODO: once we support a better build event, add support for merging two event streams\n        // together.\n        success = success && event.success;\n      }, error => {\n        obs.error(error);\n      }, () => {\n        obs.next({ success });\n        obs.complete();\n      });\n\n      // Allow subscriptions to us to unsubscribe from each builds at the same time.\n      return () => subscription.unsubscribe();\n    }).pipe(\n      switchMap(event => {\n        if (!event.success) {\n          return of(event);\n        }\n\n        return this.renderUniversal(options);\n      }),\n    );\n  }\n\n  build(targetString: string, overrides: {}) {\n    const architect = this.context.architect;\n    const [project, target, configuration] = targetString.split(':');\n\n    // Override browser build watch setting.\n    const builderConfig = architect.getBuilderConfiguration<{}>({\n      project,\n      target,\n      configuration,\n      overrides,\n    });\n\n    return architect.run(builderConfig, this.context);\n  }\n\n  getServerModuleBundlePath(options: BuildWebpackAppShellSchema) {\n    const architect = this.context.architect;\n\n    return new Observable<Path>(obs => {\n      if (options.appModuleBundle) {\n        obs.next(join(this.context.workspace.root, options.appModuleBundle));\n\n        return obs.complete();\n      } else {\n        const [project, target, configuration] = options.serverTarget.split(':');\n        const builderConfig = architect.getBuilderConfiguration<BuildWebpackServerSchema>({\n          project,\n          target,\n          configuration,\n        });\n\n        return architect.getBuilderDescription(builderConfig).pipe(\n          concatMap(description => architect.validateBuilderOptions(builderConfig, description)),\n          switchMap(config => {\n            const outputPath = join(this.context.workspace.root, config.options.outputPath);\n\n            return this.context.host.list(outputPath).pipe(\n              switchMap(files => {\n                const re = /^main\\.(?:[a-zA-Z0-9]{20}\\.)?(?:bundle\\.)?js$/;\n                const maybeMain = files.filter(x => re.test(x))[0];\n\n                if (!maybeMain) {\n                  return throwError(new Error('Could not find the main bundle.'));\n                } else {\n                  return of(join(outputPath, maybeMain));\n                }\n              }),\n            );\n          }),\n        ).subscribe(obs);\n      }\n    });\n  }\n\n  getBrowserIndexOutputPath(options: BuildWebpackAppShellSchema) {\n    const architect = this.context.architect;\n    const [project, target, configuration] = options.browserTarget.split(':');\n    const builderConfig = architect.getBuilderConfiguration<BuildWebpackServerSchema>({\n      project,\n      target,\n      configuration,\n    });\n\n    return architect.getBuilderDescription(builderConfig).pipe(\n      concatMap(description => architect.validateBuilderOptions(builderConfig, description)),\n      map(config => join(normalize(config.options.outputPath), 'index.html')),\n    );\n  }\n\n  renderUniversal(options: BuildWebpackAppShellSchema): Observable<BuildEvent> {\n    return forkJoin(\n      this.getBrowserIndexOutputPath(options).pipe(\n        switchMap(browserIndexOutputPath => {\n          const path = join(this.context.workspace.root, browserIndexOutputPath);\n\n          return this.context.host.read(path).pipe(\n            map<virtualFs.FileBuffer, [Path, virtualFs.FileBuffer]>(x => {\n              return [browserIndexOutputPath, x];\n            }),\n          );\n        }),\n      ),\n      this.getServerModuleBundlePath(options),\n    ).pipe(\n      switchMap(([[browserIndexOutputPath, indexContent], serverBundlePath]) => {\n        const root = this.context.workspace.root;\n        requireProjectModule(getSystemPath(root), 'zone.js/dist/zone-node');\n\n        const renderModuleFactory = requireProjectModule(\n          getSystemPath(root),\n          '@angular/platform-server',\n        ).renderModuleFactory;\n        const AppServerModuleNgFactory = require(\n          getSystemPath(serverBundlePath),\n        ).AppServerModuleNgFactory;\n        const indexHtml = virtualFs.fileBufferToString(indexContent);\n        const outputPath = join(root, options.outputIndexPath || browserIndexOutputPath);\n\n        // Render to HTML and overwrite the client index file.\n        return from(\n          renderModuleFactory(AppServerModuleNgFactory, {\n            document: indexHtml,\n            url: options.route,\n          })\n          .then((html: string) => {\n            return this.context.host\n              .write(outputPath, virtualFs.stringToFileBuffer(html))\n              .toPromise();\n          })\n          .then(() => ({ success: true })),\n        );\n      }),\n    );\n  }\n}\n\nexport default AppShellBuilder;\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/app-shell/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { Path, getSystemPath, join, normalize, resolve, virtualFs } from '@angular-devkit/core';\nimport { Observable, forkJoin, from, merge, of, throwError } from 'rxjs';\nimport { concatMap, map, switchMap } from 'rxjs/operators';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { augmentAppWithServiceWorker } from '../angular-cli-files/utilities/service-worker';\nimport { BrowserBuilderSchema } from '../browser/schema';\nimport { BuildWebpackServerSchema } from '../server/schema';\nimport { BuildWebpackAppShellSchema } from './schema';\n\n\nexport class AppShellBuilder implements Builder<BuildWebpackAppShellSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BuildWebpackAppShellSchema>): Observable<BuildEvent> {\n    const options = builderConfig.options;\n\n    return new Observable<BuildEvent>(obs => {\n      let success = true;\n      const subscription = merge(\n        this.build(options.serverTarget, {}),\n        // Never run the browser target in watch mode.\n        // If service worker is needed, it will be added in this.renderUniversal();\n        this.build(options.browserTarget, { watch: false, serviceWorker: false }),\n      ).subscribe((event: BuildEvent) => {\n        // TODO: once we support a better build event, add support for merging two event streams\n        // together.\n        success = success && event.success;\n      }, error => {\n        obs.error(error);\n      }, () => {\n        obs.next({ success });\n        obs.complete();\n      });\n\n      // Allow subscriptions to us to unsubscribe from each builds at the same time.\n      return () => subscription.unsubscribe();\n    }).pipe(\n      switchMap(event => {\n        if (!event.success) {\n          return of(event);\n        }\n\n        return this.renderUniversal(options);\n      }),\n    );\n  }\n\n  build(targetString: string, overrides: {}) {\n    const architect = this.context.architect;\n    const [project, target, configuration] = targetString.split(':');\n\n    // Override browser build watch setting.\n    const builderConfig = architect.getBuilderConfiguration<{}>({\n      project,\n      target,\n      configuration,\n      overrides,\n    });\n\n    return architect.run(builderConfig, this.context);\n  }\n\n  getServerModuleBundlePath(options: BuildWebpackAppShellSchema) {\n    const architect = this.context.architect;\n\n    return new Observable<Path>(obs => {\n      if (options.appModuleBundle) {\n        obs.next(join(this.context.workspace.root, options.appModuleBundle));\n\n        return obs.complete();\n      } else {\n        const [project, target, configuration] = options.serverTarget.split(':');\n        const builderConfig = architect.getBuilderConfiguration<BuildWebpackServerSchema>({\n          project,\n          target,\n          configuration,\n        });\n\n        return architect.getBuilderDescription(builderConfig).pipe(\n          concatMap(description => architect.validateBuilderOptions(builderConfig, description)),\n          switchMap(config => {\n            const outputPath = join(this.context.workspace.root, config.options.outputPath);\n\n            return this.context.host.list(outputPath).pipe(\n              switchMap(files => {\n                const re = /^main\\.(?:[a-zA-Z0-9]{20}\\.)?(?:bundle\\.)?js$/;\n                const maybeMain = files.filter(x => re.test(x))[0];\n\n                if (!maybeMain) {\n                  return throwError(new Error('Could not find the main bundle.'));\n                } else {\n                  return of(join(outputPath, maybeMain));\n                }\n              }),\n            );\n          }),\n        ).subscribe(obs);\n      }\n    });\n  }\n\n  getBrowserBuilderConfig(options: BuildWebpackAppShellSchema) {\n    const architect = this.context.architect;\n    const [project, target, configuration] = options.browserTarget.split(':');\n    const builderConfig = architect.getBuilderConfiguration<BrowserBuilderSchema>({\n      project,\n      target,\n      configuration,\n    });\n\n    return architect.getBuilderDescription(builderConfig).pipe(\n      concatMap(description => architect.validateBuilderOptions(builderConfig, description)),\n    );\n  }\n\n  renderUniversal(options: BuildWebpackAppShellSchema): Observable<BuildEvent> {\n    let browserOptions: BrowserBuilderSchema;\n    let projectRoot: Path;\n\n    return forkJoin(\n      this.getBrowserBuilderConfig(options).pipe(\n        switchMap(config => {\n          browserOptions = config.options;\n          projectRoot = resolve(this.context.workspace.root, config.root);\n          const browserIndexOutputPath = join(normalize(browserOptions.outputPath), 'index.html');\n          const path = join(this.context.workspace.root, browserIndexOutputPath);\n\n          return this.context.host.read(path).pipe(\n            map<virtualFs.FileBuffer, [Path, virtualFs.FileBuffer]>(x => {\n              return [browserIndexOutputPath, x];\n            }),\n          );\n        }),\n      ),\n      this.getServerModuleBundlePath(options),\n    ).pipe(\n      switchMap(([[browserIndexOutputPath, indexContent], serverBundlePath]) => {\n        const root = this.context.workspace.root;\n        requireProjectModule(getSystemPath(root), 'zone.js/dist/zone-node');\n\n        const renderModuleFactory = requireProjectModule(\n          getSystemPath(root),\n          '@angular/platform-server',\n        ).renderModuleFactory;\n        const AppServerModuleNgFactory = require(\n          getSystemPath(serverBundlePath),\n        ).AppServerModuleNgFactory;\n        const indexHtml = virtualFs.fileBufferToString(indexContent);\n        const outputIndexPath = join(root, options.outputIndexPath || browserIndexOutputPath);\n\n        // Render to HTML and overwrite the client index file.\n        return from(\n          renderModuleFactory(AppServerModuleNgFactory, {\n            document: indexHtml,\n            url: options.route,\n          })\n          .then((html: string) => {\n            return this.context.host\n              .write(outputIndexPath, virtualFs.stringToFileBuffer(html))\n              .toPromise();\n          })\n          .then(() => {\n            if (browserOptions.serviceWorker) {\n              return augmentAppWithServiceWorker(\n                this.context.host,\n                root,\n                projectRoot,\n                join(root, browserOptions.outputPath),\n                browserOptions.baseHref || '/',\n                browserOptions.ngswConfigPath,\n              );\n            }\n          })\n          .then(() => ({ success: true })),\n        );\n      }),\n    );\n  }\n}\n\nexport default AppShellBuilder;\n"]}
@@ -21,7 +21,7 @@ export declare class BrowserBuilder implements Builder<BrowserBuilderSchema> {
21
21
  constructor(context: BuilderContext);
22
22
  run(builderConfig: BuilderConfiguration<BrowserBuilderSchema>): Observable<BuildEvent>;
23
23
  buildWebpackConfig(root: Path, projectRoot: Path, host: virtualFs.Host<fs.Stats>, options: NormalizedBrowserBuilderSchema): any;
24
- private _deleteOutputDir(root, outputPath, host);
24
+ private _deleteOutputDir;
25
25
  }
26
26
  export declare const getBrowserLoggingCb: (verbose: boolean) => LoggingCallback;
27
27
  export default BrowserBuilder;
@@ -26,10 +26,6 @@ class BrowserBuilder {
26
26
  : rxjs_1.of(null)), operators_1.concatMap(() => utils_1.normalizeFileReplacements(options.fileReplacements, host, root)), operators_1.tap(fileReplacements => options.fileReplacements = fileReplacements), operators_1.concatMap(() => utils_1.normalizeAssetPatterns(options.assets, host, root, projectRoot, builderConfig.sourceRoot)),
27
27
  // Replace the assets in options with the normalized version.
28
28
  operators_1.tap((assetPatternObjects => options.assets = assetPatternObjects)), operators_1.concatMap(() => {
29
- // Ensure Build Optimizer is only used with AOT.
30
- if (options.buildOptimizer && !options.aot) {
31
- throw new Error('The `--build-optimizer` option cannot be used without `--aot`.');
32
- }
33
29
  let webpackConfig;
34
30
  try {
35
31
  webpackConfig = this.buildWebpackConfig(root, projectRoot, host, options);
@@ -55,6 +51,10 @@ class BrowserBuilder {
55
51
  }));
56
52
  }
57
53
  buildWebpackConfig(root, projectRoot, host, options) {
54
+ // Ensure Build Optimizer is only used with AOT.
55
+ if (options.buildOptimizer && !options.aot) {
56
+ throw new Error('The `--build-optimizer` option cannot be used without `--aot`.');
57
+ }
58
58
  let wco;
59
59
  const tsConfigPath = core_1.getSystemPath(core_1.normalize(core_1.resolve(root, core_1.normalize(options.tsConfig))));
60
60
  const tsConfig = read_tsconfig_1.readTsconfig(tsConfigPath);
@@ -69,6 +69,7 @@ class BrowserBuilder {
69
69
  tsConfigPath,
70
70
  supportES2015,
71
71
  };
72
+ wco.buildOptions.progress = utils_1.defaultProgress(wco.buildOptions.progress);
72
73
  const webpackConfigs = [
73
74
  webpack_configs_1.getCommonConfig(wco),
74
75
  webpack_configs_1.getBrowserConfig(wco),
@@ -113,4 +114,4 @@ exports.getBrowserLoggingCb = (verbose) => (stats, config, logger) => {
113
114
  }
114
115
  };
115
116
  exports.default = BrowserBuilder;
116
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/browser/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { LoggingCallback, WebpackBuilder } from '@angular-devkit/build-webpack';\nimport { Path, getSystemPath, normalize, resolve, virtualFs } from '@angular-devkit/core';\nimport * as fs from 'fs';\nimport { Observable, concat, of, throwError } from 'rxjs';\nimport { concatMap, last, tap } from 'rxjs/operators';\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { WebpackConfigOptions } from '../angular-cli-files/models/build-options';\nimport {\n  getAotConfig,\n  getBrowserConfig,\n  getCommonConfig,\n  getNonAotConfig,\n  getStatsConfig,\n  getStylesConfig,\n} from '../angular-cli-files/models/webpack-configs';\nimport { readTsconfig } from '../angular-cli-files/utilities/read-tsconfig';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { augmentAppWithServiceWorker } from '../angular-cli-files/utilities/service-worker';\nimport {\n  statsErrorsToString,\n  statsToString,\n  statsWarningsToString,\n} from '../angular-cli-files/utilities/stats';\nimport { normalizeAssetPatterns, normalizeFileReplacements } from '../utils';\nimport { AssetPatternObject, BrowserBuilderSchema, CurrentFileReplacement } from './schema';\nconst webpackMerge = require('webpack-merge');\n\n\n// TODO: figure out a better way to normalize assets, extra entry points, file replacements,\n// and whatever else needs to be normalized, while keeping type safety.\n// Right now this normalization has to be done in all other builders that make use of the\n// BrowserBuildSchema and BrowserBuilder.buildWebpackConfig.\n// It would really help if it happens during architect.validateBuilderOptions, or similar.\nexport interface NormalizedBrowserBuilderSchema extends BrowserBuilderSchema {\n  assets: AssetPatternObject[];\n  fileReplacements: CurrentFileReplacement[];\n}\n\nexport class BrowserBuilder implements Builder<BrowserBuilderSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BrowserBuilderSchema>): Observable<BuildEvent> {\n    const options = builderConfig.options;\n    const root = this.context.workspace.root;\n    const projectRoot = resolve(root, builderConfig.root);\n    const host = new virtualFs.AliasHost(this.context.host as virtualFs.Host<fs.Stats>);\n    const webpackBuilder = new WebpackBuilder({ ...this.context, host });\n\n    return of(null).pipe(\n      concatMap(() => options.deleteOutputPath\n        ? this._deleteOutputDir(root, normalize(options.outputPath), this.context.host)\n        : of(null)),\n      concatMap(() => normalizeFileReplacements(options.fileReplacements, host, root)),\n      tap(fileReplacements => options.fileReplacements = fileReplacements),\n      concatMap(() => normalizeAssetPatterns(\n        options.assets, host, root, projectRoot, builderConfig.sourceRoot)),\n      // Replace the assets in options with the normalized version.\n      tap((assetPatternObjects => options.assets = assetPatternObjects)),\n      concatMap(() => {\n        // Ensure Build Optimizer is only used with AOT.\n        if (options.buildOptimizer && !options.aot) {\n          throw new Error('The `--build-optimizer` option cannot be used without `--aot`.');\n        }\n\n        let webpackConfig;\n        try {\n          webpackConfig = this.buildWebpackConfig(root, projectRoot, host,\n            options as NormalizedBrowserBuilderSchema);\n        } catch (e) {\n          return throwError(e);\n        }\n\n        return webpackBuilder.runWebpack(webpackConfig, getBrowserLoggingCb(options.verbose));\n      }),\n      concatMap(buildEvent => {\n        if (buildEvent.success && !options.watch && options.serviceWorker) {\n          return new Observable(obs => {\n            augmentAppWithServiceWorker(\n              this.context.host,\n              root,\n              projectRoot,\n              resolve(root, normalize(options.outputPath)),\n              options.baseHref || '/',\n              options.ngswConfigPath,\n            ).then(\n              () => {\n                obs.next({ success: true });\n                obs.complete();\n              },\n              (err: Error) => {\n                obs.error(err);\n              },\n            );\n          });\n        } else {\n          return of(buildEvent);\n        }\n      }),\n    );\n  }\n\n  buildWebpackConfig(\n    root: Path,\n    projectRoot: Path,\n    host: virtualFs.Host<fs.Stats>,\n    options: NormalizedBrowserBuilderSchema,\n  ) {\n    let wco: WebpackConfigOptions<NormalizedBrowserBuilderSchema>;\n\n    const tsConfigPath = getSystemPath(normalize(resolve(root, normalize(options.tsConfig))));\n    const tsConfig = readTsconfig(tsConfigPath);\n\n    const projectTs = requireProjectModule(getSystemPath(projectRoot), 'typescript') as typeof ts;\n\n    const supportES2015 = tsConfig.options.target !== projectTs.ScriptTarget.ES3\n      && tsConfig.options.target !== projectTs.ScriptTarget.ES5;\n\n    wco = {\n      root: getSystemPath(root),\n      projectRoot: getSystemPath(projectRoot),\n      buildOptions: options,\n      tsConfig,\n      tsConfigPath,\n      supportES2015,\n    };\n\n    const webpackConfigs: {}[] = [\n      getCommonConfig(wco),\n      getBrowserConfig(wco),\n      getStylesConfig(wco),\n      getStatsConfig(wco),\n    ];\n\n    if (wco.buildOptions.main || wco.buildOptions.polyfills) {\n      const typescriptConfigPartial = wco.buildOptions.aot\n        ? getAotConfig(wco, host)\n        : getNonAotConfig(wco, host);\n      webpackConfigs.push(typescriptConfigPartial);\n    }\n\n    return webpackMerge(webpackConfigs);\n  }\n\n  private _deleteOutputDir(root: Path, outputPath: Path, host: virtualFs.Host) {\n    const resolvedOutputPath = resolve(root, outputPath);\n    if (resolvedOutputPath === root) {\n      throw new Error('Output path MUST not be project root directory!');\n    }\n\n    return host.exists(resolvedOutputPath).pipe(\n      concatMap(exists => exists\n        // TODO: remove this concat once host ops emit an event.\n        ? concat(host.delete(resolvedOutputPath), of(null)).pipe(last())\n        // ? of(null)\n        : of(null)),\n    );\n  }\n}\n\nexport const getBrowserLoggingCb = (verbose: boolean): LoggingCallback =>\n  (stats, config, logger) => {\n    // config.stats contains our own stats settings, added during buildWebpackConfig().\n    const json = stats.toJson(config.stats);\n    if (verbose) {\n      logger.info(stats.toString(config.stats));\n    } else {\n      logger.info(statsToString(json, config.stats));\n    }\n\n    if (stats.hasWarnings()) {\n      logger.warn(statsWarningsToString(json, config.stats));\n    }\n    if (stats.hasErrors()) {\n      logger.error(statsErrorsToString(json, config.stats));\n    }\n  };\n\nexport default BrowserBuilder;\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/angular_devkit/build_angular/src/browser/index.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport {\n  BuildEvent,\n  Builder,\n  BuilderConfiguration,\n  BuilderContext,\n} from '@angular-devkit/architect';\nimport { LoggingCallback, WebpackBuilder } from '@angular-devkit/build-webpack';\nimport { Path, getSystemPath, normalize, resolve, virtualFs } from '@angular-devkit/core';\nimport * as fs from 'fs';\nimport { Observable, concat, of, throwError } from 'rxjs';\nimport { concatMap, last, tap } from 'rxjs/operators';\nimport * as ts from 'typescript'; // tslint:disable-line:no-implicit-dependencies\nimport { WebpackConfigOptions } from '../angular-cli-files/models/build-options';\nimport {\n  getAotConfig,\n  getBrowserConfig,\n  getCommonConfig,\n  getNonAotConfig,\n  getStatsConfig,\n  getStylesConfig,\n} from '../angular-cli-files/models/webpack-configs';\nimport { readTsconfig } from '../angular-cli-files/utilities/read-tsconfig';\nimport { requireProjectModule } from '../angular-cli-files/utilities/require-project-module';\nimport { augmentAppWithServiceWorker } from '../angular-cli-files/utilities/service-worker';\nimport {\n  statsErrorsToString,\n  statsToString,\n  statsWarningsToString,\n} from '../angular-cli-files/utilities/stats';\nimport { defaultProgress, normalizeAssetPatterns, normalizeFileReplacements } from '../utils';\nimport { AssetPatternObject, BrowserBuilderSchema, CurrentFileReplacement } from './schema';\nconst webpackMerge = require('webpack-merge');\n\n\n// TODO: figure out a better way to normalize assets, extra entry points, file replacements,\n// and whatever else needs to be normalized, while keeping type safety.\n// Right now this normalization has to be done in all other builders that make use of the\n// BrowserBuildSchema and BrowserBuilder.buildWebpackConfig.\n// It would really help if it happens during architect.validateBuilderOptions, or similar.\nexport interface NormalizedBrowserBuilderSchema extends BrowserBuilderSchema {\n  assets: AssetPatternObject[];\n  fileReplacements: CurrentFileReplacement[];\n}\n\nexport class BrowserBuilder implements Builder<BrowserBuilderSchema> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<BrowserBuilderSchema>): Observable<BuildEvent> {\n    const options = builderConfig.options;\n    const root = this.context.workspace.root;\n    const projectRoot = resolve(root, builderConfig.root);\n    const host = new virtualFs.AliasHost(this.context.host as virtualFs.Host<fs.Stats>);\n    const webpackBuilder = new WebpackBuilder({ ...this.context, host });\n\n    return of(null).pipe(\n      concatMap(() => options.deleteOutputPath\n        ? this._deleteOutputDir(root, normalize(options.outputPath), this.context.host)\n        : of(null)),\n      concatMap(() => normalizeFileReplacements(options.fileReplacements, host, root)),\n      tap(fileReplacements => options.fileReplacements = fileReplacements),\n      concatMap(() => normalizeAssetPatterns(\n        options.assets, host, root, projectRoot, builderConfig.sourceRoot)),\n      // Replace the assets in options with the normalized version.\n      tap((assetPatternObjects => options.assets = assetPatternObjects)),\n      concatMap(() => {\n        let webpackConfig;\n        try {\n          webpackConfig = this.buildWebpackConfig(root, projectRoot, host,\n            options as NormalizedBrowserBuilderSchema);\n        } catch (e) {\n          return throwError(e);\n        }\n\n        return webpackBuilder.runWebpack(webpackConfig, getBrowserLoggingCb(options.verbose));\n      }),\n      concatMap(buildEvent => {\n        if (buildEvent.success && !options.watch && options.serviceWorker) {\n          return new Observable(obs => {\n            augmentAppWithServiceWorker(\n              this.context.host,\n              root,\n              projectRoot,\n              resolve(root, normalize(options.outputPath)),\n              options.baseHref || '/',\n              options.ngswConfigPath,\n            ).then(\n              () => {\n                obs.next({ success: true });\n                obs.complete();\n              },\n              (err: Error) => {\n                obs.error(err);\n              },\n            );\n          });\n        } else {\n          return of(buildEvent);\n        }\n      }),\n    );\n  }\n\n  buildWebpackConfig(\n    root: Path,\n    projectRoot: Path,\n    host: virtualFs.Host<fs.Stats>,\n    options: NormalizedBrowserBuilderSchema,\n  ) {\n    // Ensure Build Optimizer is only used with AOT.\n    if (options.buildOptimizer && !options.aot) {\n      throw new Error('The `--build-optimizer` option cannot be used without `--aot`.');\n    }\n\n    let wco: WebpackConfigOptions<NormalizedBrowserBuilderSchema>;\n\n    const tsConfigPath = getSystemPath(normalize(resolve(root, normalize(options.tsConfig))));\n    const tsConfig = readTsconfig(tsConfigPath);\n\n    const projectTs = requireProjectModule(getSystemPath(projectRoot), 'typescript') as typeof ts;\n\n    const supportES2015 = tsConfig.options.target !== projectTs.ScriptTarget.ES3\n      && tsConfig.options.target !== projectTs.ScriptTarget.ES5;\n\n    wco = {\n      root: getSystemPath(root),\n      projectRoot: getSystemPath(projectRoot),\n      buildOptions: options,\n      tsConfig,\n      tsConfigPath,\n      supportES2015,\n    };\n\n    wco.buildOptions.progress = defaultProgress(wco.buildOptions.progress);\n\n    const webpackConfigs: {}[] = [\n      getCommonConfig(wco),\n      getBrowserConfig(wco),\n      getStylesConfig(wco),\n      getStatsConfig(wco),\n    ];\n\n    if (wco.buildOptions.main || wco.buildOptions.polyfills) {\n      const typescriptConfigPartial = wco.buildOptions.aot\n        ? getAotConfig(wco, host)\n        : getNonAotConfig(wco, host);\n      webpackConfigs.push(typescriptConfigPartial);\n    }\n\n    return webpackMerge(webpackConfigs);\n  }\n\n  private _deleteOutputDir(root: Path, outputPath: Path, host: virtualFs.Host) {\n    const resolvedOutputPath = resolve(root, outputPath);\n    if (resolvedOutputPath === root) {\n      throw new Error('Output path MUST not be project root directory!');\n    }\n\n    return host.exists(resolvedOutputPath).pipe(\n      concatMap(exists => exists\n        // TODO: remove this concat once host ops emit an event.\n        ? concat(host.delete(resolvedOutputPath), of(null)).pipe(last())\n        // ? of(null)\n        : of(null)),\n    );\n  }\n}\n\nexport const getBrowserLoggingCb = (verbose: boolean): LoggingCallback =>\n  (stats, config, logger) => {\n    // config.stats contains our own stats settings, added during buildWebpackConfig().\n    const json = stats.toJson(config.stats);\n    if (verbose) {\n      logger.info(stats.toString(config.stats));\n    } else {\n      logger.info(statsToString(json, config.stats));\n    }\n\n    if (stats.hasWarnings()) {\n      logger.warn(statsWarningsToString(json, config.stats));\n    }\n    if (stats.hasErrors()) {\n      logger.error(statsErrorsToString(json, config.stats));\n    }\n  };\n\nexport default BrowserBuilder;\n"]}
@@ -42,7 +42,7 @@ export interface BrowserBuilderSchema {
42
42
  stylePreprocessorOptions?: StylePreprocessorOptions;
43
43
 
44
44
  /**
45
- * Defines the optimization level of the build.
45
+ * Enables optimization of the build output.
46
46
  */
47
47
  optimization: boolean;
48
48
 
@@ -104,7 +104,7 @@ export interface BrowserBuilderSchema {
104
104
  /**
105
105
  * Log progress to the console while building.
106
106
  */
107
- progress: boolean;
107
+ progress?: boolean;
108
108
 
109
109
  /**
110
110
  * Localization file to use for i18n.
@@ -55,7 +55,7 @@
55
55
  },
56
56
  "optimization": {
57
57
  "type": "boolean",
58
- "description": "Defines the optimization level of the build.",
58
+ "description": "Enables optimization of the build output.",
59
59
  "default": false
60
60
  },
61
61
  "fileReplacements": {
@@ -115,8 +115,7 @@
115
115
  },
116
116
  "progress": {
117
117
  "type": "boolean",
118
- "description": "Log progress to the console while building.",
119
- "default": true
118
+ "description": "Log progress to the console while building."
120
119
  },
121
120
  "i18nFile": {
122
121
  "type": "string",
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  /**
3
2
  * @license
4
3
  * Copyright Google Inc. All Rights Reserved.
@@ -6,6 +5,7 @@
6
5
  * Use of this source code is governed by an MIT-style license that can be
7
6
  * found in the LICENSE file at https://angular.io/license
8
7
  */
8
+ /// <reference types="node" />
9
9
  import { BuildEvent, Builder, BuilderConfiguration, BuilderContext } from '@angular-devkit/architect';
10
10
  import { Path, virtualFs } from '@angular-devkit/core';
11
11
  import * as fs from 'fs';
@@ -31,6 +31,7 @@ export interface DevServerBuilderOptions {
31
31
  optimization?: boolean;
32
32
  aot?: boolean;
33
33
  sourceMap?: boolean;
34
+ vendorSourceMap?: boolean;
34
35
  evalSourceMap?: boolean;
35
36
  vendorChunk?: boolean;
36
37
  commonChunk?: boolean;
@@ -43,12 +44,12 @@ export declare class DevServerBuilder implements Builder<DevServerBuilderOptions
43
44
  constructor(context: BuilderContext);
44
45
  run(builderConfig: BuilderConfiguration<DevServerBuilderOptions>): Observable<BuildEvent>;
45
46
  buildWebpackConfig(root: Path, projectRoot: Path, host: virtualFs.Host<fs.Stats>, browserOptions: BrowserBuilderSchema): any;
46
- private _buildServerConfig(root, projectRoot, options, browserOptions);
47
- private _addLiveReload(options, browserOptions, webpackConfig, clientAddress);
48
- private _addSslConfig(root, options, config);
49
- private _addProxyConfig(root, options, config);
50
- private _buildServePath(options, browserOptions);
51
- private _findDefaultServePath(baseHref?, deployUrl?);
52
- private _getBrowserOptions(options);
47
+ private _buildServerConfig;
48
+ private _addLiveReload;
49
+ private _addSslConfig;
50
+ private _addProxyConfig;
51
+ private _buildServePath;
52
+ private _findDefaultServePath;
53
+ private _getBrowserOptions;
53
54
  }
54
55
  export default DevServerBuilder;