@anansi/webpack-config
Version:
Production ready webpack for React
156 lines (155 loc) • 19.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault").default;
exports.__esModule = true;
exports.default = makeDevConfig;
var _htmlWebpackPlugin = _interopRequireDefault(require("html-webpack-plugin"));
var _path = _interopRequireDefault(require("path"));
var _webpack = _interopRequireDefault(require("webpack"));
var _runtime = _interopRequireDefault(require("webpack/lib/logging/runtime"));
var _base = require("./base");
var _getHttpsConfig = _interopRequireDefault(require("./getHttpsConfig"));
var _ErrorOverlayPlugin = _interopRequireDefault(require("./plugins/ErrorOverlayPlugin"));
const chalk = require('react-dev-utils/chalk');
function makeDevConfig(baseConfig, {
rootPath,
basePath,
libraryInclude,
libraryExclude,
htmlOptions = {
title: 'Anansi app',
scriptLoading: 'defer'
},
argv = {},
// eslint-disable-next-line no-unused-vars
env = {},
sassOptions,
sassResources,
cssModulesOptions,
globalStyleDir,
isStackblitz,
cssExtractOptions
}) {
const config = {
...baseConfig
};
config.mode = 'development';
// https://webpack.js.org/guides/build-performance/#output-without-path-info
config.output.pathinfo = false;
config.output.devtoolModuleFilenameTemplate = info => _path.default.resolve(info.absoluteResourcePath).replace(/\\/g, '/');
config.optimization = {
// https://webpack.js.org/guides/build-performance/#avoid-extra-optimization-steps
removeAvailableModules: false,
removeEmptyChunks: false,
splitChunks: false,
// save perf when errors occur
emitOnErrors: false,
// https://webpack.js.org/guides/build-performance/#minimal-entry-chunk
runtimeChunk: true
};
const watchIgnorePaths = [/(hot-update\.[^.]|\.map|s?css\.d\.ts)$/, _path.default.join(rootPath, '.cache'), /node_modules\/\.cache(?!\/(\.wyw-in-js-(cache|development|production)\/))/];
config.plugins = [new _webpack.default.WatchIgnorePlugin({
paths: watchIgnorePaths
}), ...config.plugins];
// not for server builds
if (!argv?.target?.includes?.('node')) {
config.plugins.unshift(new _htmlWebpackPlugin.default(htmlOptions));
}
let server = 'http';
try {
server = (0, _getHttpsConfig.default)(rootPath);
} catch (e) {
console.warn(chalk.yellow('Falling back to http'));
}
config.devServer = {
hot: true,
compress: true,
headers: {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Methods': '*',
'Access-Control-Allow-Headers': '*'
},
allowedHosts: ['localhost', '127.0.0.1', '.csb.app'],
server,
devMiddleware: {
publicPath: config.output.publicPath,
stats: {
preset: 'minimal',
children: 'errors-only',
excludeAssets: [/\.map/]
}
},
client: {
logging: 'warn',
overlay: false,
// we have our own overlay, so ignore this
webSocketURL: {
hostname: 'localhost',
pathname: '/ws',
port: argv.port
}
},
historyApiFallback: true
// TODO: add proxy options
};
config.devtool = 'cheap-module-source-map';
// if we know the port, force it in case this is encapsulated in another host
if (argv.port) {
config.output.publicPath = `http://localhost:${argv.port}${config.output.publicPath}`;
}
if (!config.resolve.alias) {
config.resolve.alias = {};
}
if (process.env.NO_HOT_RELOAD !== 'true' && process.env.NO_HOT_RELOAD !== true && !argv?.target?.includes?.('node')) {
try {
require('react-refresh/babel');
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');
config.plugins.push(
// these are needed by the react-dev-utils overlay
new _webpack.default.EnvironmentPlugin({
WDS_SOCKET_HOST: '',
WDS_SOCKET_PATH: '',
WDS_SOCKET_PORT: '',
FAST_REFRESH: true
}), new ReactRefreshWebpackPlugin({
overlay: {
// provides editor opening when combined with ErrorOverlayPlugin
entry: require.resolve('./plugins/ErrorOverlayEntry'),
// registers error handlers
module: require.resolve('./plugins/refreshOverlayModule'),
sockHost: config.devServer.client.webSocketURL.hostname,
sockPath: config.devServer.client.webSocketURL.pathname,
sockPort: config.devServer.client.webSocketURL.port
}
}), new _ErrorOverlayPlugin.default());
config.devServer.hot = 'only';
_runtime.default.getLogger('anansi').info('React fast refresh detected and enabled');
// eslint-disable-next-line no-empty
} catch (e) {}
}
if (!config.experiments) {
config.experiments = {};
}
// this doesn't work well with webcontainers
if (!isStackblitz) {
// TODO: enable once we can figure out how to make it work with manifest and await for SSR
//config.experiments.lazyCompilation = { entries: false };
}
const styleRules = (0, _base.getStyleRules)({
rootPath,
basePath,
libraryInclude,
libraryExclude,
cssModulesOptions: {
localIdentName: '[folder]_[name]__[local]___[xxhash64:hash:base64:5]',
...cssModulesOptions
},
sassOptions,
sassResources,
globalStyleDir,
target: argv?.target,
cssExtractOptions
});
config.module.rules = [...config.module.rules, styleRules];
return config;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_htmlWebpackPlugin","_interopRequireDefault","require","_path","_webpack","_runtime","_base","_getHttpsConfig","_ErrorOverlayPlugin","chalk","makeDevConfig","baseConfig","rootPath","basePath","libraryInclude","libraryExclude","htmlOptions","title","scriptLoading","argv","env","sassOptions","sassResources","cssModulesOptions","globalStyleDir","isStackblitz","cssExtractOptions","config","mode","output","pathinfo","devtoolModuleFilenameTemplate","info","path","resolve","absoluteResourcePath","replace","optimization","removeAvailableModules","removeEmptyChunks","splitChunks","emitOnErrors","runtimeChunk","watchIgnorePaths","join","plugins","webpack","WatchIgnorePlugin","paths","target","includes","unshift","HtmlWebpackPlugin","server","getHttpsConfig","e","console","warn","yellow","devServer","hot","compress","headers","allowedHosts","devMiddleware","publicPath","stats","preset","children","excludeAssets","client","logging","overlay","webSocketURL","hostname","pathname","port","historyApiFallback","devtool","alias","process","NO_HOT_RELOAD","ReactRefreshWebpackPlugin","push","EnvironmentPlugin","WDS_SOCKET_HOST","WDS_SOCKET_PATH","WDS_SOCKET_PORT","FAST_REFRESH","entry","module","sockHost","sockPath","sockPort","ErrorOverlayPlugin","getLogger","experiments","styleRules","getStyleRules","localIdentName","rules"],"sources":["../src/dev.js"],"sourcesContent":["import HtmlWebpackPlugin from 'html-webpack-plugin';\nimport path from 'path';\nimport webpack from 'webpack';\nimport logging from 'webpack/lib/logging/runtime';\n\nimport { getStyleRules } from './base';\nimport getHttpsConfig from './getHttpsConfig';\nimport ErrorOverlayPlugin from './plugins/ErrorOverlayPlugin';\n\nconst chalk = require('react-dev-utils/chalk');\n\nexport default function makeDevConfig(\n  baseConfig,\n  {\n    rootPath,\n    basePath,\n    libraryInclude,\n    libraryExclude,\n    htmlOptions = { title: 'Anansi app', scriptLoading: 'defer' },\n    argv = {},\n    // eslint-disable-next-line no-unused-vars\n    env = {},\n    sassOptions,\n    sassResources,\n    cssModulesOptions,\n    globalStyleDir,\n    isStackblitz,\n    cssExtractOptions,\n  },\n) {\n  const config = { ...baseConfig };\n\n  config.mode = 'development';\n  // https://webpack.js.org/guides/build-performance/#output-without-path-info\n  config.output.pathinfo = false;\n  config.output.devtoolModuleFilenameTemplate = info =>\n    path.resolve(info.absoluteResourcePath).replace(/\\\\/g, '/');\n  config.optimization = {\n    // https://webpack.js.org/guides/build-performance/#avoid-extra-optimization-steps\n    removeAvailableModules: false,\n    removeEmptyChunks: false,\n    splitChunks: false,\n    // save perf when errors occur\n    emitOnErrors: false,\n    // https://webpack.js.org/guides/build-performance/#minimal-entry-chunk\n    runtimeChunk: true,\n  };\n\n  const watchIgnorePaths = [\n    /(hot-update\\.[^.]|\\.map|s?css\\.d\\.ts)$/,\n    path.join(rootPath, '.cache'),\n    /node_modules\\/\\.cache(?!\\/(\\.wyw-in-js-(cache|development|production)\\/))/,\n  ];\n  config.plugins = [\n    new webpack.WatchIgnorePlugin({ paths: watchIgnorePaths }),\n    ...config.plugins,\n  ];\n  // not for server builds\n  if (!argv?.target?.includes?.('node')) {\n    config.plugins.unshift(new HtmlWebpackPlugin(htmlOptions));\n  }\n  let server = 'http';\n  try {\n    server = getHttpsConfig(rootPath);\n  } catch (e) {\n    console.warn(chalk.yellow('Falling back to http'));\n  }\n  config.devServer = {\n    hot: true,\n    compress: true,\n    headers: {\n      'Access-Control-Allow-Origin': '*',\n      'Access-Control-Allow-Methods': '*',\n      'Access-Control-Allow-Headers': '*',\n    },\n    allowedHosts: ['localhost', '127.0.0.1', '.csb.app'],\n    server,\n    devMiddleware: {\n      publicPath: config.output.publicPath,\n      stats: {\n        preset: 'minimal',\n        children: 'errors-only',\n        excludeAssets: [/\\.map/],\n      },\n    },\n    client: {\n      logging: 'warn',\n      overlay: false, // we have our own overlay, so ignore this\n      webSocketURL: {\n        hostname: 'localhost',\n        pathname: '/ws',\n        port: argv.port,\n      },\n    },\n    historyApiFallback: true,\n    // TODO: add proxy options\n  };\n  config.devtool = 'cheap-module-source-map';\n  // if we know the port, force it in case this is encapsulated in another host\n  if (argv.port) {\n    config.output.publicPath = `http://localhost:${argv.port}${config.output.publicPath}`;\n  }\n  if (!config.resolve.alias) {\n    config.resolve.alias = {};\n  }\n  if (\n    process.env.NO_HOT_RELOAD !== 'true' &&\n    process.env.NO_HOT_RELOAD !== true &&\n    !argv?.target?.includes?.('node')\n  ) {\n    try {\n      require('react-refresh/babel');\n      const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');\n      config.plugins.push(\n        // these are needed by the react-dev-utils overlay\n        new webpack.EnvironmentPlugin({\n          WDS_SOCKET_HOST: '',\n          WDS_SOCKET_PATH: '',\n          WDS_SOCKET_PORT: '',\n          FAST_REFRESH: true,\n        }),\n        new ReactRefreshWebpackPlugin({\n          overlay: {\n            // provides editor opening when combined with ErrorOverlayPlugin\n            entry: require.resolve('./plugins/ErrorOverlayEntry'),\n            // registers error handlers\n            module: require.resolve('./plugins/refreshOverlayModule'),\n            sockHost: config.devServer.client.webSocketURL.hostname,\n            sockPath: config.devServer.client.webSocketURL.pathname,\n            sockPort: config.devServer.client.webSocketURL.port,\n          },\n        }),\n        new ErrorOverlayPlugin(),\n      );\n      config.devServer.hot = 'only';\n      logging\n        .getLogger('anansi')\n        .info('React fast refresh detected and enabled');\n      // eslint-disable-next-line no-empty\n    } catch (e) {}\n  }\n\n  if (!config.experiments) {\n    config.experiments = {};\n  }\n  // this doesn't work well with webcontainers\n  if (!isStackblitz) {\n    // TODO: enable once we can figure out how to make it work with manifest and await for SSR\n    //config.experiments.lazyCompilation = { entries: false };\n  }\n\n  const styleRules = getStyleRules({\n    rootPath,\n    basePath,\n    libraryInclude,\n    libraryExclude,\n    cssModulesOptions: {\n      localIdentName: '[folder]_[name]__[local]___[xxhash64:hash:base64:5]',\n      ...cssModulesOptions,\n    },\n    sassOptions,\n    sassResources,\n    globalStyleDir,\n    target: argv?.target,\n    cssExtractOptions,\n  });\n  config.module.rules = [...config.module.rules, styleRules];\n  return config;\n}\n"],"mappings":"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","ignoreList":[]}