UNPKG

roadhog-extra

Version:

Cli tool for serve and build react app, based on create-react-app, support JSON pattern config.

127 lines (96 loc) 5.23 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; exports.default = function (args, appBuild, config, paths) { var watch = args.watch, debug = args.debug, analyze = args.analyze; var NODE_ENV = debug ? 'development' : process.env.NODE_ENV; var _config$publicPath = config.publicPath, publicPath = _config$publicPath === undefined ? '/' : _config$publicPath, _config$library = config.library, library = _config$library === undefined ? null : _config$library, _config$libraryTarget = config.libraryTarget, libraryTarget = _config$libraryTarget === undefined ? 'var' : _config$libraryTarget, _config$devtool = config.devtool, devtool = _config$devtool === undefined ? debug ? _common.defaultDevtool : false : _config$devtool; var babelOptions = (0, _common.getBabelOptions)(config); var cssLoaders = (0, _getCSSLoaders2.default)(config); var theme = (0, _getTheme2.default)(process.cwd(), config); // Support hash var jsFileName = config.hash ? '[name].[chunkhash:8]' : '[name]'; var cssFileName = config.hash ? '[name].[contenthash:8]' : '[name]'; var output = { path: appBuild, filename: (config.assetsPath && config.assetsPath.js ? config.assetsPath.js : 'assets/js/') + (jsFileName + '.js'), publicPath: publicPath, libraryTarget: libraryTarget, chunkFilename: (config.assetsPath && config.assetsPath.js ? config.assetsPath.js : 'assets/js/') + (jsFileName + '.async.js') }; if (library) output.library = library; var finalWebpackConfig = _extends({ bail: true, devtool: devtool, entry: (0, _getEntry2.default)(config, paths.appDirectory, /* isBuild */true), output: output }, (0, _common.getResolve)(config, paths), { module: { rules: [].concat(_toConsumableArray((0, _common.getFirstRules)({ config: config, paths: paths, babelOptions: babelOptions })), _toConsumableArray((0, _common.getCSSRules)('production', { config: config, paths: paths, cssLoaders: cssLoaders, theme: theme })), _toConsumableArray((0, _common.getLastRules)({ paths: paths, babelOptions: babelOptions }))) }, plugins: [].concat(_toConsumableArray(watch ? [] : [new _webpack2.default.optimize.OccurrenceOrderPlugin(), new _webpack2.default.optimize.DedupePlugin()]), [new _extractTextWebpackPlugin2.default({ filename: (config.assetsPath && config.assetsPath.css ? config.assetsPath.css : 'assets/css/') + (cssFileName + '.css'), allChunks: true })], _toConsumableArray((0, _common.getCommonPlugins)({ config: config, paths: paths, appBuild: appBuild, NODE_ENV: NODE_ENV })), _toConsumableArray(debug ? [] : [new _webpack2.default.optimize.UglifyJsPlugin({ compress: { screw_ie8: true, // React doesn't support IE8 warnings: false }, mangle: { screw_ie8: true }, output: { comments: false, screw_ie8: true, ascii_only: true } })]), _toConsumableArray(analyze ? [new _webpackVisualizerPlugin2.default()] : [])), externals: config.externals, node: _common.node }); var _baseSvgLoader = (0, _common.baseSvgLoader)(config); if (config.svgSpriteLoaderDirs) { _baseSvgLoader.exclude = config.svgSpriteLoaderDirs; _common.spriteSvgLoader.include = config.svgSpriteLoaderDirs; finalWebpackConfig.module.rules.push(_baseSvgLoader); finalWebpackConfig.module.rules.push(_common.spriteSvgLoader); } else { finalWebpackConfig.module.rules.push(_baseSvgLoader); } var prodConfig = (0, _addExtraBabelIncludes2.default)(config, finalWebpackConfig, paths, config.extraBabelIncludes, babelOptions); return prodConfig; }; var _webpack = require('webpack'); var _webpack2 = _interopRequireDefault(_webpack); var _extractTextWebpackPlugin = require('extract-text-webpack-plugin'); var _extractTextWebpackPlugin2 = _interopRequireDefault(_extractTextWebpackPlugin); var _webpackVisualizerPlugin = require('webpack-visualizer-plugin'); var _webpackVisualizerPlugin2 = _interopRequireDefault(_webpackVisualizerPlugin); var _getEntry = require('../utils/getEntry'); var _getEntry2 = _interopRequireDefault(_getEntry); var _getTheme = require('../utils/getTheme'); var _getTheme2 = _interopRequireDefault(_getTheme); var _getCSSLoaders = require('../utils/getCSSLoaders'); var _getCSSLoaders2 = _interopRequireDefault(_getCSSLoaders); var _addExtraBabelIncludes = require('../utils/addExtraBabelIncludes'); var _addExtraBabelIncludes2 = _interopRequireDefault(_addExtraBabelIncludes); var _common = require('./common'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } module.exports = exports['default'];