const helpers = require('./helpers')
const webpackMerge = require('webpack-merge') // used to merge webpack configs
+const webpackMergeDll = webpackMerge.strategy({plugins: 'replace'})
const commonConfig = require('./webpack.common.js') // the settings that are common to prod and dev
/**
* Webpack Plugins
*/
+const AddAssetHtmlPlugin = require('add-asset-html-webpack-plugin')
const DefinePlugin = require('webpack/lib/DefinePlugin')
const NamedModulesPlugin = require('webpack/lib/NamedModulesPlugin')
const LoaderOptionsPlugin = require('webpack/lib/LoaderOptionsPlugin')
HMR: HMR
})
+const DllBundlesPlugin = require('webpack-dll-bundles-plugin').DllBundlesPlugin
+
/**
* Webpack configuration
*
}
}),
+ new DllBundlesPlugin({
+ bundles: {
+ polyfills: [
+ 'core-js',
+ {
+ name: 'zone.js',
+ path: 'zone.js/dist/zone.js'
+ },
+ {
+ name: 'zone.js',
+ path: 'zone.js/dist/long-stack-trace-zone.js'
+ },
+ 'ts-helpers'
+ ],
+ vendor: [
+ '@angular/platform-browser',
+ '@angular/platform-browser-dynamic',
+ '@angular/core',
+ '@angular/common',
+ '@angular/forms',
+ '@angular/http',
+ '@angular/router',
+ '@angularclass/hmr',
+ 'rxjs'
+ ]
+ },
+ dllDir: helpers.root('dll'),
+ webpackConfig: webpackMergeDll(commonConfig({env: ENV}), {
+ devtool: 'cheap-module-source-map',
+ plugins: []
+ })
+ }),
+
+ /**
+ * Plugin: AddAssetHtmlPlugin
+ * Description: Adds the given JS or CSS file to the files
+ * Webpack knows about, and put it into the list of assets
+ * html-webpack-plugin injects into the generated html.
+ *
+ * See: https://github.com/SimenB/add-asset-html-webpack-plugin
+ */
+ new AddAssetHtmlPlugin([
+ { filepath: helpers.root(`dll/${DllBundlesPlugin.resolveFile('polyfills')}`) },
+ { filepath: helpers.root(`dll/${DllBundlesPlugin.resolveFile('vendor')}`) }
+ ]),
+
/**
* Plugin: NamedModulesPlugin (experimental)
* Description: Uses file names as module name.