UNPKG

@farris/build-angular

Version:

Angular Webpack Build Facade

273 lines 37.6 kB
"use strict"; /** * @license * Copyright Google Inc. All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ // tslint:disable // TODO: cleanup this file, it's copied as is from Angular CLI. Object.defineProperty(exports, "__esModule", { value: true }); const path = require("path"); const webpack_1 = require("webpack"); const CopyWebpackPlugin = require("copy-webpack-plugin"); const utils_1 = require("./utils"); const is_directory_1 = require("../../utilities/is-directory"); const require_project_module_1 = require("../../utilities/require-project-module"); const bundle_budget_1 = require("../../plugins/bundle-budget"); const cleancss_webpack_plugin_1 = require("../../plugins/cleancss-webpack-plugin"); const scripts_webpack_plugin_1 = require("../../plugins/scripts-webpack-plugin"); const find_up_1 = require("../../utilities/find-up"); const utils_2 = require("./utils"); const ProgressPlugin = require('webpack/lib/ProgressPlugin'); const CircularDependencyPlugin = require('circular-dependency-plugin'); const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); const StatsPlugin = require('stats-webpack-plugin'); /** * Enumerate loaders and their dependencies from this file to let the dependency validator * know they are used. * * require('source-map-loader') * require('raw-loader') * require('url-loader') * require('file-loader') * require('@angular-devkit/build-optimizer') */ const g = typeof global !== 'undefined' ? global : {}; exports.buildOptimizerLoader = g['_DevKitIsLocal'] ? require.resolve('@angular-devkit/build-optimizer/src/build-optimizer/webpack-loader') : '@angular-devkit/build-optimizer/webpack-loader'; function getCommonConfig(wco) { const { root, projectRoot, buildOptions } = wco; const nodeModules = find_up_1.findUp('node_modules', projectRoot); if (!nodeModules) { throw new Error('Cannot locate node_modules directory.'); } let extraPlugins = []; let entryPoints = {}; if (buildOptions.main) { entryPoints['main'] = [path.resolve(root, buildOptions.main)]; } if (buildOptions.polyfills) { entryPoints['polyfills'] = [path.resolve(root, buildOptions.polyfills)]; } // determine hashing format const hashFormat = utils_1.getOutputHashFormat(buildOptions.outputHashing); // process global scripts if (buildOptions.scripts.length > 0) { const globalScriptsByBundleName = utils_2.normalizeExtraEntryPoints(buildOptions.scripts, 'scripts') .reduce((prev, curr) => { const bundleName = curr.bundleName; const resolvedPath = path.resolve(root, curr.input); let existingEntry = prev.find((el) => el.bundleName === bundleName); if (existingEntry) { if (existingEntry.lazy && !curr.lazy) { // All entries have to be lazy for the bundle to be lazy. throw new Error(`The ${curr.bundleName} bundle is mixing lazy and non-lazy scripts.`); } existingEntry.paths.push(resolvedPath); } else { prev.push({ bundleName, paths: [resolvedPath], lazy: curr.lazy }); } return prev; }, []); // Add a new asset for each entry. globalScriptsByBundleName.forEach((script) => { // Lazy scripts don't get a hash, otherwise they can't be loaded by name. const hash = script.lazy ? '' : hashFormat.script; const bundleName = script.bundleName; extraPlugins.push(new scripts_webpack_plugin_1.ScriptsWebpackPlugin({ name: bundleName, sourceMap: buildOptions.sourceMap, filename: `${path.basename(bundleName)}${hash}.js`, scripts: script.paths, basePath: projectRoot, })); }); } // process asset entries if (buildOptions.assets) { const copyWebpackPluginPatterns = buildOptions.assets.map((asset) => { // Resolve input paths relative to workspace root and add slash at the end. asset.input = path.resolve(root, asset.input).replace(/\\/g, '/'); asset.input = asset.input.endsWith('/') ? asset.input : asset.input + '/'; asset.output = asset.output.endsWith('/') ? asset.output : asset.output + '/'; if (asset.output.startsWith('..')) { const message = 'An asset cannot be written to a location outside of the output path.'; throw new Error(message); } return { context: asset.input, // Now we remove starting slash to make Webpack place it from the output root. to: asset.output.replace(/^\//, ''), from: { glob: asset.glob, dot: true } }; }); const copyWebpackPluginOptions = { ignore: ['.gitkeep', '**/.DS_Store', '**/Thumbs.db'] }; const newCopyWebpackPluginPatterns = [...copyWebpackPluginPatterns, { from: 'dist-reference', to: '' }]; const copyWebpackPluginInstance = new CopyWebpackPlugin(newCopyWebpackPluginPatterns, copyWebpackPluginOptions); // Save options so we can use them in eject. copyWebpackPluginInstance['copyWebpackPluginPatterns'] = copyWebpackPluginPatterns; copyWebpackPluginInstance['copyWebpackPluginOptions'] = copyWebpackPluginOptions; extraPlugins.push(copyWebpackPluginInstance); } if (buildOptions.progress) { extraPlugins.push(new ProgressPlugin({ profile: buildOptions.verbose, colors: true })); } if (buildOptions.showCircularDependencies) { extraPlugins.push(new CircularDependencyPlugin({ exclude: /[\\\/]node_modules[\\\/]/ })); } if (buildOptions.statsJson) { extraPlugins.push(new StatsPlugin('stats.json', 'verbose')); } let sourceMapUseRule; if (buildOptions.sourceMap && buildOptions.vendorSourceMap) { sourceMapUseRule = { use: [ { loader: 'source-map-loader' } ] }; } let buildOptimizerUseRule; if (buildOptions.buildOptimizer) { buildOptimizerUseRule = { use: [ { loader: exports.buildOptimizerLoader, options: { sourceMap: buildOptions.sourceMap } }, ], }; } // Allow loaders to be in a node_modules nested inside the devkit/build-angular package. // This is important in case loaders do not get hoisted. // If this file moves to another location, alter potentialNodeModules as well. const loaderNodeModules = ['node_modules']; const buildAngularNodeModules = find_up_1.findUp('node_modules', __dirname); if (buildAngularNodeModules && is_directory_1.isDirectory(buildAngularNodeModules) && buildAngularNodeModules !== nodeModules && buildAngularNodeModules.startsWith(nodeModules)) { loaderNodeModules.push(buildAngularNodeModules); } // Load rxjs path aliases. // https://github.com/ReactiveX/rxjs/blob/master/doc/lettable-operators.md#build-and-treeshaking let alias = {}; try { const rxjsPathMappingImport = wco.supportES2015 ? 'rxjs/_esm2015/path-mapping' : 'rxjs/_esm5/path-mapping'; const rxPaths = require_project_module_1.requireProjectModule(projectRoot, rxjsPathMappingImport); alias = rxPaths(nodeModules); } catch (_a) { } const uglifyOptions = Object.assign({ ecma: wco.supportES2015 ? 6 : 5, warnings: !!buildOptions.verbose, safari10: true, output: { ascii_only: true, comments: false, webkit: true, } }, (buildOptions.platform == 'server' ? {} : { compress: { pure_getters: buildOptions.buildOptimizer, // PURE comments work best with 3 passes. // See https://github.com/webpack/webpack/issues/2899#issuecomment-317425926. passes: buildOptions.buildOptimizer ? 3 : 1, // Workaround known uglify-es issue // See https://github.com/mishoo/UglifyJS2/issues/2949#issuecomment-368070307 inline: wco.supportES2015 ? 1 : 3, } }), (buildOptions.platform == 'server' ? { mangle: false } : {})); return { mode: buildOptions.optimization ? 'production' : 'development', devtool: false, resolve: { extensions: ['.ts', '.tsx', '.mjs', '.js'], symlinks: !buildOptions.preserveSymlinks, modules: [ wco.tsConfig.options.baseUrl || projectRoot, 'node_modules', ], alias }, resolveLoader: { modules: loaderNodeModules }, context: projectRoot, entry: entryPoints, output: { path: path.resolve(root, buildOptions.outputPath), publicPath: buildOptions.deployUrl, filename: `[name]${hashFormat.chunk}.js`, }, watch: buildOptions.watch, watchOptions: { poll: buildOptions.poll }, performance: { hints: false, }, module: { rules: [ { test: /\.html$/, loader: 'raw-loader' }, { test: /\.(eot|svg|cur)$/, loader: 'file-loader', options: { name: `[name]${hashFormat.file}.[ext]`, limit: 10000 } }, { test: /\.(jpg|png|webp|gif|otf|ttf|woff|woff2|ani)$/, loader: 'url-loader', options: { name: `[name]${hashFormat.file}.[ext]`, limit: 10000 } }, { // Mark files inside `@angular/core` as using SystemJS style dynamic imports. // Removing this will cause deprecation warnings to appear. test: /[\/\\]@angular[\/\\]core[\/\\].+\.js$/, parser: { system: true }, }, Object.assign({ test: /\.js$/ }, buildOptimizerUseRule), Object.assign({ test: /\.js$/, exclude: /(ngfactory|ngstyle).js$/, enforce: 'pre' }, sourceMapUseRule), ] }, optimization: { noEmitOnErrors: true, minimizer: [ new webpack_1.HashedModuleIdsPlugin(), // TODO: check with Mike what this feature needs. new bundle_budget_1.BundleBudgetPlugin({ budgets: buildOptions.budgets }), new cleancss_webpack_plugin_1.CleanCssWebpackPlugin({ sourceMap: buildOptions.sourceMap, // component styles retain their original file name test: (file) => /\.(?:css|scss|sass|less|styl)$/.test(file), }), new UglifyJSPlugin({ sourceMap: buildOptions.sourceMap, parallel: true, cache: true, uglifyOptions, }), ], }, plugins: extraPlugins, }; } exports.getCommonConfig = getCommonConfig; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common.js","sourceRoot":"./","sources":["packages/farris_devkit/build_angular/src/angular-cli-files/models/webpack-configs/common.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.\n\nimport * as path from 'path';\nimport { HashedModuleIdsPlugin } from 'webpack';\nimport * as CopyWebpackPlugin from 'copy-webpack-plugin';\nimport { getOutputHashFormat } from './utils';\nimport { isDirectory } from '../../utilities/is-directory';\nimport { requireProjectModule } from '../../utilities/require-project-module';\nimport { WebpackConfigOptions } from '../build-options';\nimport { BundleBudgetPlugin } from '../../plugins/bundle-budget';\nimport { CleanCssWebpackPlugin } from '../../plugins/cleancss-webpack-plugin';\nimport { ScriptsWebpackPlugin } from '../../plugins/scripts-webpack-plugin';\nimport { findUp } from '../../utilities/find-up';\nimport { AssetPatternObject, ExtraEntryPoint } from '../../../browser/schema';\nimport { normalizeExtraEntryPoints } from './utils';\n\nconst ProgressPlugin = require('webpack/lib/ProgressPlugin');\nconst CircularDependencyPlugin = require('circular-dependency-plugin');\nconst UglifyJSPlugin = require('uglifyjs-webpack-plugin');\nconst StatsPlugin = require('stats-webpack-plugin');\n\n/**\n * Enumerate loaders and their dependencies from this file to let the dependency validator\n * know they are used.\n *\n * require('source-map-loader')\n * require('raw-loader')\n * require('url-loader')\n * require('file-loader')\n * require('@angular-devkit/build-optimizer')\n */\n\nconst g: any = typeof global !== 'undefined' ? global : {};\nexport const buildOptimizerLoader: string = g['_DevKitIsLocal']\n  ? require.resolve('@angular-devkit/build-optimizer/src/build-optimizer/webpack-loader')\n  : '@angular-devkit/build-optimizer/webpack-loader';\n\nexport function getCommonConfig(wco: WebpackConfigOptions) {\n  const { root, projectRoot, buildOptions } = wco;\n\n  const nodeModules = findUp('node_modules', projectRoot);\n  if (!nodeModules) {\n    throw new Error('Cannot locate node_modules directory.')\n  }\n\n  let extraPlugins: any[] = [];\n  let entryPoints: { [key: string]: string[] } = {};\n\n  if (buildOptions.main) {\n    entryPoints['main'] = [path.resolve(root, buildOptions.main)];\n  }\n\n  if (buildOptions.polyfills) {\n    entryPoints['polyfills'] = [path.resolve(root, buildOptions.polyfills)];\n  }\n\n  // determine hashing format\n  const hashFormat = getOutputHashFormat(buildOptions.outputHashing as any);\n\n  // process global scripts\n  if (buildOptions.scripts.length > 0) {\n    const globalScriptsByBundleName = normalizeExtraEntryPoints(buildOptions.scripts, 'scripts')\n      .reduce((prev: { bundleName: string, paths: string[], lazy: boolean }[], curr) => {\n        const bundleName = curr.bundleName;\n        const resolvedPath = path.resolve(root, curr.input);\n        let existingEntry = prev.find((el) => el.bundleName === bundleName);\n        if (existingEntry) {\n          if (existingEntry.lazy && !curr.lazy) {\n            // All entries have to be lazy for the bundle to be lazy.\n            throw new Error(`The ${curr.bundleName} bundle is mixing lazy and non-lazy scripts.`);\n          }\n\n          existingEntry.paths.push(resolvedPath);\n\n        } else {\n          prev.push({\n            bundleName,\n            paths: [resolvedPath],\n            lazy: curr.lazy\n          });\n        }\n        return prev;\n      }, []);\n\n\n    // Add a new asset for each entry.\n    globalScriptsByBundleName.forEach((script) => {\n      // Lazy scripts don't get a hash, otherwise they can't be loaded by name.\n      const hash = script.lazy ? '' : hashFormat.script;\n      const bundleName = script.bundleName;\n\n      extraPlugins.push(new ScriptsWebpackPlugin({\n        name: bundleName,\n        sourceMap: buildOptions.sourceMap,\n        filename: `${path.basename(bundleName)}${hash}.js`,\n        scripts: script.paths,\n        basePath: projectRoot,\n      }));\n    });\n  }\n\n  // process asset entries\n  if (buildOptions.assets) {\n    const copyWebpackPluginPatterns = buildOptions.assets.map((asset: AssetPatternObject) => {\n\n      // Resolve input paths relative to workspace root and add slash at the end.\n      asset.input = path.resolve(root, asset.input).replace(/\\\\/g, '/');\n      asset.input = asset.input.endsWith('/') ? asset.input : asset.input + '/';\n      asset.output = asset.output.endsWith('/') ? asset.output : asset.output + '/';\n\n      if (asset.output.startsWith('..')) {\n        const message = 'An asset cannot be written to a location outside of the output path.';\n        throw new Error(message);\n      }\n\n      return {\n        context: asset.input,\n        // Now we remove starting slash to make Webpack place it from the output root.\n        to: asset.output.replace(/^\\//, ''),\n        from: {\n          glob: asset.glob,\n          dot: true\n        }\n      };\n    });\n\n    const copyWebpackPluginOptions = { ignore: ['.gitkeep', '**/.DS_Store', '**/Thumbs.db'] };\n    const newCopyWebpackPluginPatterns = [...copyWebpackPluginPatterns, { from: 'dist-reference', to: '' }]\n    const copyWebpackPluginInstance = new CopyWebpackPlugin(newCopyWebpackPluginPatterns,\n      copyWebpackPluginOptions);\n\n    // Save options so we can use them in eject.\n    (copyWebpackPluginInstance as any)['copyWebpackPluginPatterns'] = copyWebpackPluginPatterns;\n    (copyWebpackPluginInstance as any)['copyWebpackPluginOptions'] = copyWebpackPluginOptions;\n\n    extraPlugins.push(copyWebpackPluginInstance);\n  }\n\n  if (buildOptions.progress) {\n    extraPlugins.push(new ProgressPlugin({ profile: buildOptions.verbose, colors: true }));\n  }\n\n  if (buildOptions.showCircularDependencies) {\n    extraPlugins.push(new CircularDependencyPlugin({\n      exclude: /[\\\\\\/]node_modules[\\\\\\/]/\n    }));\n  }\n\n  if (buildOptions.statsJson) {\n    extraPlugins.push(new StatsPlugin('stats.json', 'verbose'));\n  }\n\n  let sourceMapUseRule;\n  if (buildOptions.sourceMap && buildOptions.vendorSourceMap) {\n    sourceMapUseRule = {\n      use: [\n        {\n          loader: 'source-map-loader'\n        }\n      ]\n    }\n  }\n\n  let buildOptimizerUseRule;\n  if (buildOptions.buildOptimizer) {\n    buildOptimizerUseRule = {\n      use: [\n        {\n          loader: buildOptimizerLoader,\n          options: { sourceMap: buildOptions.sourceMap }\n        },\n      ],\n    };\n  }\n\n  // Allow loaders to be in a node_modules nested inside the devkit/build-angular package.\n  // This is important in case loaders do not get hoisted.\n  // If this file moves to another location, alter potentialNodeModules as well.\n  const loaderNodeModules = ['node_modules'];\n  const buildAngularNodeModules = findUp('node_modules', __dirname);\n  if (buildAngularNodeModules\n    && isDirectory(buildAngularNodeModules)\n    && buildAngularNodeModules !== nodeModules\n    && buildAngularNodeModules.startsWith(nodeModules)\n  ) {\n    loaderNodeModules.push(buildAngularNodeModules);\n  }\n\n  // Load rxjs path aliases.\n  // https://github.com/ReactiveX/rxjs/blob/master/doc/lettable-operators.md#build-and-treeshaking\n  let alias = {};\n  try {\n    const rxjsPathMappingImport = wco.supportES2015\n      ? 'rxjs/_esm2015/path-mapping'\n      : 'rxjs/_esm5/path-mapping';\n    const rxPaths = requireProjectModule(projectRoot, rxjsPathMappingImport);\n    alias = rxPaths(nodeModules);\n  } catch { }\n\n  const uglifyOptions = {\n    ecma: wco.supportES2015 ? 6 : 5,\n    warnings: !!buildOptions.verbose,\n    safari10: true,\n    output: {\n      ascii_only: true,\n      comments: false,\n      webkit: true,\n    },\n\n    // On server, we don't want to compress anything.\n    ...(buildOptions.platform == 'server' ? {} : {\n      compress: {\n        pure_getters: buildOptions.buildOptimizer,\n        // PURE comments work best with 3 passes.\n        // See https://github.com/webpack/webpack/issues/2899#issuecomment-317425926.\n        passes: buildOptions.buildOptimizer ? 3 : 1,\n        // Workaround known uglify-es issue\n        // See https://github.com/mishoo/UglifyJS2/issues/2949#issuecomment-368070307\n        inline: wco.supportES2015 ? 1 : 3,\n      }\n    }),\n    // We also want to avoid mangling on server.\n    ...(buildOptions.platform == 'server' ? { mangle: false } : {})\n  };\n\n  return {\n    mode: buildOptions.optimization ? 'production' : 'development',\n    devtool: false,\n    resolve: {\n      extensions: ['.ts', '.tsx', '.mjs', '.js'],\n      symlinks: !buildOptions.preserveSymlinks,\n      modules: [\n        wco.tsConfig.options.baseUrl || projectRoot,\n        'node_modules',\n      ],\n      alias\n    },\n    resolveLoader: {\n      modules: loaderNodeModules\n    },\n    context: projectRoot,\n    entry: entryPoints,\n    output: {\n      path: path.resolve(root, buildOptions.outputPath as string),\n      publicPath: buildOptions.deployUrl,\n      filename: `[name]${hashFormat.chunk}.js`,\n    },\n    watch: buildOptions.watch,\n    watchOptions: {\n      poll: buildOptions.poll\n    },\n    performance: {\n      hints: false,\n    },\n    module: {\n      rules: [\n        { test: /\\.html$/, loader: 'raw-loader' },\n        {\n          test: /\\.(eot|svg|cur)$/,\n          loader: 'file-loader',\n          options: {\n            name: `[name]${hashFormat.file}.[ext]`,\n            limit: 10000\n          }\n        },\n        {\n          test: /\\.(jpg|png|webp|gif|otf|ttf|woff|woff2|ani)$/,\n          loader: 'url-loader',\n          options: {\n            name: `[name]${hashFormat.file}.[ext]`,\n            limit: 10000\n          }\n        },\n        {\n          // Mark files inside `@angular/core` as using SystemJS style dynamic imports.\n          // Removing this will cause deprecation warnings to appear.\n          test: /[\\/\\\\]@angular[\\/\\\\]core[\\/\\\\].+\\.js$/,\n          parser: { system: true },\n        },\n        {\n          test: /\\.js$/,\n          ...buildOptimizerUseRule,\n        },\n        {\n          test: /\\.js$/,\n          exclude: /(ngfactory|ngstyle).js$/,\n          enforce: 'pre',\n          ...sourceMapUseRule,\n        },\n      ]\n    },\n    optimization: {\n      noEmitOnErrors: true,\n      minimizer: [\n        new HashedModuleIdsPlugin(),\n        // TODO: check with Mike what this feature needs.\n        new BundleBudgetPlugin({ budgets: buildOptions.budgets }),\n        new CleanCssWebpackPlugin({\n          sourceMap: buildOptions.sourceMap,\n          // component styles retain their original file name\n          test: (file) => /\\.(?:css|scss|sass|less|styl)$/.test(file),\n        }),\n        new UglifyJSPlugin({\n          sourceMap: buildOptions.sourceMap,\n          parallel: true,\n          cache: true,\n          uglifyOptions,\n        }),\n      ],\n    },\n    plugins: extraPlugins,\n  };\n}\n"]}