UNPKG

@anansi/webpack-config

Version:
156 lines (155 loc) 19.8 kB
"use strict"; 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":[]}