UNPKG

@farris/build-angular

Version:

Angular Webpack Build Facade

97 lines 17 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); const build_webpack_1 = require("@angular-devkit/build-webpack"); const core_1 = require("@angular-devkit/core"); const path = require("path"); const operators_1 = require("rxjs/operators"); const webpack = require("webpack"); const webpack_configs_1 = require("../angular-cli-files/models/webpack-configs"); const read_tsconfig_1 = require("../angular-cli-files/utilities/read-tsconfig"); const stats_1 = require("../angular-cli-files/utilities/stats"); const webpackMerge = require('webpack-merge'); class ExtractI18nBuilder { constructor(context) { this.context = context; } run(builderConfig) { const architect = this.context.architect; const options = builderConfig.options; const root = this.context.workspace.root; const projectRoot = core_1.resolve(root, builderConfig.root); const [project, targetName, configuration] = options.browserTarget.split(':'); // Override browser build watch setting. const overrides = { watch: false }; const browserTargetSpec = { project, target: targetName, configuration, overrides }; const browserBuilderConfig = architect.getBuilderConfiguration(browserTargetSpec); const webpackBuilder = new build_webpack_1.WebpackBuilder(this.context); const loggingCb = (stats, config, logger) => { const json = stats.toJson(); if (stats.hasWarnings()) { this.context.logger.warn(stats_1.statsWarningsToString(json, config.stats)); } if (stats.hasErrors()) { this.context.logger.error(stats_1.statsErrorsToString(json, config.stats)); } }; return architect.getBuilderDescription(browserBuilderConfig).pipe(operators_1.concatMap(browserDescription => architect.validateBuilderOptions(browserBuilderConfig, browserDescription)), operators_1.map(browserBuilderConfig => browserBuilderConfig.options), operators_1.concatMap((validatedBrowserOptions) => { const browserOptions = validatedBrowserOptions; // We need to determine the outFile name so that AngularCompiler can retrieve it. let outFile = options.outFile || getI18nOutfile(options.i18nFormat); if (options.outputPath) { // AngularCompilerPlugin doesn't support genDir so we have to adjust outFile instead. outFile = path.join(options.outputPath, outFile); } // Extracting i18n uses the browser target webpack config with some specific options. const webpackConfig = this.buildWebpackConfig(root, projectRoot, Object.assign({}, browserOptions, { optimization: false, i18nLocale: options.i18nLocale, i18nFormat: options.i18nFormat, i18nFile: outFile, aot: true, assets: [], scripts: [], styles: [] })); return webpackBuilder.runWebpack(webpackConfig, loggingCb); })); } buildWebpackConfig(root, projectRoot, options) { let wco; const host = new core_1.virtualFs.AliasHost(this.context.host); const tsConfigPath = core_1.getSystemPath(core_1.normalize(core_1.resolve(root, core_1.normalize(options.tsConfig)))); const tsConfig = read_tsconfig_1.readTsconfig(tsConfigPath); wco = { root: core_1.getSystemPath(root), projectRoot: core_1.getSystemPath(projectRoot), // TODO: use only this.options, it contains all flags and configs items already. buildOptions: options, tsConfig, tsConfigPath, supportES2015: false, }; const webpackConfigs = [ // We don't need to write to disk. { plugins: [new InMemoryOutputPlugin()] }, webpack_configs_1.getCommonConfig(wco), webpack_configs_1.getAotConfig(wco, host, true), webpack_configs_1.getStylesConfig(wco), webpack_configs_1.getStatsConfig(wco), ]; return webpackMerge(webpackConfigs); } } exports.ExtractI18nBuilder = ExtractI18nBuilder; function getI18nOutfile(format) { switch (format) { case 'xmb': return 'messages.xmb'; case 'xlf': case 'xlif': case 'xliff': case 'xlf2': case 'xliff2': return 'messages.xlf'; default: throw new Error(`Unsupported format "${format}"`); } } class InMemoryOutputPlugin { constructor() { } apply(compiler) { // tslint:disable-next-line:no-any compiler.outputFileSystem = new webpack.MemoryOutputFileSystem(); } } exports.default = ExtractI18nBuilder; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"./","sources":["packages/farris_devkit/build_angular/src/extract-i18n/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 * as path from 'path';\nimport { Observable } from 'rxjs';\nimport { concatMap, map } from 'rxjs/operators';\nimport * as webpack from 'webpack';\nimport { WebpackConfigOptions } from '../angular-cli-files/models/build-options';\nimport {\n  getAotConfig,\n  getCommonConfig,\n  getStatsConfig,\n  getStylesConfig,\n} from '../angular-cli-files/models/webpack-configs';\nimport { readTsconfig } from '../angular-cli-files/utilities/read-tsconfig';\nimport { statsErrorsToString, statsWarningsToString } from '../angular-cli-files/utilities/stats';\nimport { NormalizedBrowserBuilderSchema } from '../browser';\nimport { BrowserBuilderSchema } from '../browser/schema';\nconst webpackMerge = require('webpack-merge');\n\n\nexport interface ExtractI18nBuilderOptions {\n  browserTarget: string;\n  i18nFormat: string;\n  i18nLocale: string;\n  outputPath?: string;\n  outFile?: string;\n}\n\nexport class ExtractI18nBuilder implements Builder<ExtractI18nBuilderOptions> {\n\n  constructor(public context: BuilderContext) { }\n\n  run(builderConfig: BuilderConfiguration<ExtractI18nBuilderOptions>): Observable<BuildEvent> {\n    const architect = this.context.architect;\n    const options = builderConfig.options;\n    const root = this.context.workspace.root;\n    const projectRoot = resolve(root, builderConfig.root);\n    const [project, targetName, configuration] = options.browserTarget.split(':');\n    // Override browser build watch setting.\n    const overrides = { watch: false };\n\n    const browserTargetSpec = { project, target: targetName, configuration, overrides };\n    const browserBuilderConfig = architect.getBuilderConfiguration<BrowserBuilderSchema>(\n      browserTargetSpec);\n    const webpackBuilder = new WebpackBuilder(this.context);\n\n    const loggingCb: LoggingCallback = (stats, config, logger) => {\n      const json = stats.toJson();\n      if (stats.hasWarnings()) {\n        this.context.logger.warn(statsWarningsToString(json, config.stats));\n      }\n\n      if (stats.hasErrors()) {\n        this.context.logger.error(statsErrorsToString(json, config.stats));\n      }\n    };\n\n    return architect.getBuilderDescription(browserBuilderConfig).pipe(\n      concatMap(browserDescription =>\n        architect.validateBuilderOptions(browserBuilderConfig, browserDescription)),\n      map(browserBuilderConfig => browserBuilderConfig.options),\n      concatMap((validatedBrowserOptions) => {\n        const browserOptions = validatedBrowserOptions;\n\n        // We need to determine the outFile name so that AngularCompiler can retrieve it.\n        let outFile = options.outFile || getI18nOutfile(options.i18nFormat);\n        if (options.outputPath) {\n          // AngularCompilerPlugin doesn't support genDir so we have to adjust outFile instead.\n          outFile = path.join(options.outputPath, outFile);\n        }\n\n        // Extracting i18n uses the browser target webpack config with some specific options.\n        const webpackConfig = this.buildWebpackConfig(root, projectRoot, {\n          ...browserOptions,\n          optimization: false,\n          i18nLocale: options.i18nLocale,\n          i18nFormat: options.i18nFormat,\n          i18nFile: outFile,\n          aot: true,\n          assets: [],\n          scripts: [],\n          styles: [],\n        });\n\n        return webpackBuilder.runWebpack(webpackConfig, loggingCb);\n      }),\n    );\n  }\n\n  buildWebpackConfig(\n    root: Path,\n    projectRoot: Path,\n    options: NormalizedBrowserBuilderSchema,\n  ) {\n    let wco: WebpackConfigOptions;\n\n    const host = new virtualFs.AliasHost(this.context.host as virtualFs.Host<fs.Stats>);\n\n    const tsConfigPath = getSystemPath(normalize(resolve(root, normalize(options.tsConfig))));\n    const tsConfig = readTsconfig(tsConfigPath);\n\n    wco = {\n      root: getSystemPath(root),\n      projectRoot: getSystemPath(projectRoot),\n      // TODO: use only this.options, it contains all flags and configs items already.\n      buildOptions: options,\n      tsConfig,\n      tsConfigPath,\n      supportES2015: false,\n    };\n\n    const webpackConfigs: {}[] = [\n      // We don't need to write to disk.\n      { plugins: [new InMemoryOutputPlugin()] },\n      getCommonConfig(wco),\n      getAotConfig(wco, host, true),\n      getStylesConfig(wco),\n      getStatsConfig(wco),\n    ];\n\n    return webpackMerge(webpackConfigs);\n  }\n}\n\nfunction getI18nOutfile(format: string) {\n  switch (format) {\n    case 'xmb':\n      return 'messages.xmb';\n    case 'xlf':\n    case 'xlif':\n    case 'xliff':\n    case 'xlf2':\n    case 'xliff2':\n      return 'messages.xlf';\n    default:\n      throw new Error(`Unsupported format \"${format}\"`);\n  }\n}\n\nclass InMemoryOutputPlugin {\n  constructor() { }\n\n  apply(compiler: webpack.Compiler): void {\n    // tslint:disable-next-line:no-any\n    compiler.outputFileSystem = new (webpack as any).MemoryOutputFileSystem();\n  }\n\n}\n\nexport default ExtractI18nBuilder;\n"]}