UNPKG

@farris/build-angular

Version:

Angular Webpack Build Facade

156 lines 19.9 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 HtmlWebpackPlugin = require('html-webpack-plugin'); const SubresourceIntegrityPlugin = require('webpack-subresource-integrity'); const { LazyRequirePlugin, LibReferencePlugin } = require('@farris/lazy-require'); const license_webpack_plugin_1 = require("license-webpack-plugin"); const package_chunk_sort_1 = require("../../utilities/package-chunk-sort"); const base_href_webpack_1 = require("../../lib/base-href-webpack"); const index_html_webpack_plugin_1 = require("../../plugins/index-html-webpack-plugin"); const utils_1 = require("./utils"); /** + * license-webpack-plugin has a peer dependency on webpack-sources, list it in a comment to + * let the dependency validator know it is used. + * + * require('webpack-sources') + */ function getBrowserConfig(wco) { const { root, projectRoot, buildOptions } = wco; let extraPlugins = []; // Figure out which are the lazy loaded bundle names. const lazyChunkBundleNames = utils_1.normalizeExtraEntryPoints( // We don't really need a default name because we pre-filtered by lazy only entries. [...buildOptions.styles, ...buildOptions.scripts], 'not-lazy') .filter(entry => entry.lazy) .map(entry => entry.bundleName); const generateIndexHtml = false; if (generateIndexHtml) { extraPlugins.push(new HtmlWebpackPlugin({ template: path.resolve(root, buildOptions.index), filename: path.resolve(buildOptions.outputPath, buildOptions.index), chunksSortMode: package_chunk_sort_1.packageChunkSort(buildOptions), excludeChunks: lazyChunkBundleNames, xhtml: true, minify: buildOptions.optimization ? { caseSensitive: true, collapseWhitespace: true, keepClosingSlash: true } : false })); extraPlugins.push(new base_href_webpack_1.BaseHrefWebpackPlugin({ baseHref: buildOptions.baseHref })); } let sourcemaps = false; if (buildOptions.sourceMap) { // See https://webpack.js.org/configuration/devtool/ for sourcemap types. if (buildOptions.evalSourceMap && !buildOptions.optimization) { // Produce eval sourcemaps for development with serve, which are faster. sourcemaps = 'eval'; } else { // Produce full separate sourcemaps for production. sourcemaps = 'source-map'; } } if (buildOptions.subresourceIntegrity) { extraPlugins.push(new SubresourceIntegrityPlugin({ hashFuncNames: ['sha384'] })); } if (buildOptions.extractLicenses) { extraPlugins.push(new license_webpack_plugin_1.LicenseWebpackPlugin({ pattern: /.*/, suppressErrors: true, perChunkOutput: false, outputFilename: `3rdpartylicenses.txt` })); } const globalStylesBundleNames = utils_1.normalizeExtraEntryPoints(buildOptions.styles, 'styles') .map(style => style.bundleName); return { devtool: sourcemaps, resolve: { mainFields: [ ...(wco.supportES2015 ? ['es2015'] : []), 'browser', 'module', 'main' ] }, output: { crossOriginLoading: buildOptions.subresourceIntegrity ? 'anonymous' : false }, optimization: { runtimeChunk: 'single', splitChunks: { maxAsyncRequests: Infinity, cacheGroups: { default: buildOptions.commonChunk && { chunks: 'async', minChunks: 2, priority: 10, }, common: buildOptions.commonChunk && { name: 'common', chunks: 'async', minChunks: 2, enforce: true, priority: 5, }, vendors: false, vendor: buildOptions.vendorChunk && { name: 'vendor', chunks: 'initial', enforce: true, test: (module, chunks) => { const moduleName = module.nameForCondition ? module.nameForCondition() : ''; return /[\\/]node_modules[\\/]/.test(moduleName) && !chunks.some(({ name }) => name === 'polyfills' || globalStylesBundleNames.includes(name)); }, }, } } }, plugins: extraPlugins.concat([ new index_html_webpack_plugin_1.IndexHtmlWebpackPlugin({ input: path.resolve(root, buildOptions.index), output: path.basename(buildOptions.index), baseHref: buildOptions.baseHref, entrypoints: package_chunk_sort_1.generateEntryPoints(buildOptions), deployUrl: buildOptions.deployUrl, sri: buildOptions.subresourceIntegrity, }), new LazyRequirePlugin({ // entryModules: [ // "app/lazy-module/lazy.module.ts" // ], entryModules: buildOptions.entryModules, tsConfigPath: wco.tsConfigPath }), new LibReferencePlugin({ buildTarget: 'App', reference: buildOptions.reference, // reference: [ // ["rxjs", "dist-reference/rxjs_manifest.json"], // ["angular", "dist-reference/angular_manifest.json"], // ["progress", "dist-reference/progress_manifest.json"] // ], includeContextModule: true, basePath: wco.root }) ]), node: false, }; } exports.getBrowserConfig = getBrowserConfig; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"browser.js","sourceRoot":"./","sources":["packages/farris_devkit/build_angular/src/angular-cli-files/models/webpack-configs/browser.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';\nconst HtmlWebpackPlugin = require('html-webpack-plugin');\nconst SubresourceIntegrityPlugin = require('webpack-subresource-integrity');\nconst { LazyRequirePlugin, LibReferencePlugin } = require('@farris/lazy-require');\nimport { LicenseWebpackPlugin } from 'license-webpack-plugin';\nimport { generateEntryPoints, packageChunkSort } from '../../utilities/package-chunk-sort';\nimport { BaseHrefWebpackPlugin } from '../../lib/base-href-webpack';\nimport { IndexHtmlWebpackPlugin } from '../../plugins/index-html-webpack-plugin';\nimport { ExtraEntryPoint } from '../../../browser/schema';\nimport { BrowserBuilderSchema } from '../../../browser/schema';\nimport { WebpackConfigOptions } from '../build-options';\nimport { normalizeExtraEntryPoints } from './utils';\n\n/**\n+ * license-webpack-plugin has a peer dependency on webpack-sources, list it in a comment to\n+ * let the dependency validator know it is used.\n+ *\n+ * require('webpack-sources')\n+ */\n\nexport function getBrowserConfig(wco: WebpackConfigOptions) {\n  const { root, projectRoot, buildOptions } = wco;\n\n\n  let extraPlugins: any[] = [];\n\n  // Figure out which are the lazy loaded bundle names.\n  const lazyChunkBundleNames = normalizeExtraEntryPoints(\n    // We don't really need a default name because we pre-filtered by lazy only entries.\n    [...buildOptions.styles, ...buildOptions.scripts], 'not-lazy')\n    .filter(entry => entry.lazy)\n    .map(entry => entry.bundleName)\n\n  const generateIndexHtml = false;\n  if (generateIndexHtml) {\n    extraPlugins.push(new HtmlWebpackPlugin({\n      template: path.resolve(root, buildOptions.index),\n      filename: path.resolve(buildOptions.outputPath, buildOptions.index),\n      chunksSortMode: packageChunkSort(buildOptions),\n      excludeChunks: lazyChunkBundleNames,\n      xhtml: true,\n      minify: buildOptions.optimization ? {\n        caseSensitive: true,\n        collapseWhitespace: true,\n        keepClosingSlash: true\n      } : false\n    }));\n    extraPlugins.push(new BaseHrefWebpackPlugin({\n      baseHref: buildOptions.baseHref as string\n    }));\n  }\n\n  let sourcemaps: string | false = false;\n  if (buildOptions.sourceMap) {\n    // See https://webpack.js.org/configuration/devtool/ for sourcemap types.\n    if (buildOptions.evalSourceMap && !buildOptions.optimization) {\n      // Produce eval sourcemaps for development with serve, which are faster.\n      sourcemaps = 'eval';\n    } else {\n      // Produce full separate sourcemaps for production.\n      sourcemaps = 'source-map';\n    }\n  }\n\n  if (buildOptions.subresourceIntegrity) {\n    extraPlugins.push(new SubresourceIntegrityPlugin({\n      hashFuncNames: ['sha384']\n    }));\n  }\n\n  if (buildOptions.extractLicenses) {\n    extraPlugins.push(new LicenseWebpackPlugin({\n      pattern: /.*/,\n      suppressErrors: true,\n      perChunkOutput: false,\n      outputFilename: `3rdpartylicenses.txt`\n    }));\n  }\n\n  const globalStylesBundleNames = normalizeExtraEntryPoints(buildOptions.styles, 'styles')\n    .map(style => style.bundleName);\n\n  return {\n    devtool: sourcemaps,\n    resolve: {\n      mainFields: [\n        ...(wco.supportES2015 ? ['es2015'] : []),\n        'browser', 'module', 'main'\n      ]\n    },\n    output: {\n      crossOriginLoading: buildOptions.subresourceIntegrity ? 'anonymous' : false\n    },\n    optimization: {\n      runtimeChunk: 'single',\n      splitChunks: {\n        maxAsyncRequests: Infinity,\n        cacheGroups: {\n          default: buildOptions.commonChunk && {\n            chunks: 'async',\n            minChunks: 2,\n            priority: 10,\n          },\n          common: buildOptions.commonChunk && {\n            name: 'common',\n            chunks: 'async',\n            minChunks: 2,\n            enforce: true,\n            priority: 5,\n          },\n          vendors: false,\n          vendor: buildOptions.vendorChunk && {\n            name: 'vendor',\n            chunks: 'initial',\n            enforce: true,\n            test: (module: any, chunks: Array<{ name: string }>) => {\n              const moduleName = module.nameForCondition ? module.nameForCondition() : '';\n              return /[\\\\/]node_modules[\\\\/]/.test(moduleName)\n                && !chunks.some(({ name }) => name === 'polyfills'\n                  || globalStylesBundleNames.includes(name));\n            },\n          },\n        }\n      }\n    },\n    plugins: extraPlugins.concat([\n      new IndexHtmlWebpackPlugin({\n        input: path.resolve(root, buildOptions.index),\n        output: path.basename(buildOptions.index),\n        baseHref: buildOptions.baseHref,\n        entrypoints: generateEntryPoints(buildOptions),\n        deployUrl: buildOptions.deployUrl,\n        sri: buildOptions.subresourceIntegrity,\n      }),\n      new LazyRequirePlugin({\n        // entryModules: [\n        //     \"app/lazy-module/lazy.module.ts\"\n        // ],\n        entryModules: buildOptions.entryModules,\n        tsConfigPath: wco.tsConfigPath\n      }),\n      new LibReferencePlugin({\n        buildTarget: 'App',\n        reference: buildOptions.reference,\n        // reference: [\n        //   [\"rxjs\", \"dist-reference/rxjs_manifest.json\"],\n        //   [\"angular\", \"dist-reference/angular_manifest.json\"],\n        //   [\"progress\", \"dist-reference/progress_manifest.json\"]\n        // ],\n        includeContextModule: true,\n        basePath: wco.root\n      })\n    ]),\n    node: false,\n  };\n}\n"]}