@anansi/webpack-config
Version:
Production ready webpack for React
202 lines (200 loc) • 21.9 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault").default;
exports.__esModule = true;
exports.default = getStyleRules;
var _autoprefixer = _interopRequireDefault(require("autoprefixer"));
var _miniCssExtractPlugin = _interopRequireDefault(require("mini-css-extract-plugin"));
var _path = _interopRequireDefault(require("path"));
var _postcssPresetEnv = _interopRequireDefault(require("postcss-preset-env"));
var _ramda = require("ramda");
const getCSSLoaders = ({
mode,
target,
cssExtractOptions
}) => {
const miniCssExtractPluginLoader = {
loader: _miniCssExtractPlugin.default.loader,
options: {
emit: !target?.includes?.('node')
}
};
const loaders = [{
loader: require.resolve('css-loader'),
options: mode === 'development' ? {
sourceMap: true,
importLoaders: 1,
modules: {
mode: 'icss'
}
} : {
importLoaders: 1,
modules: {
mode: 'icss'
}
}
}, {
loader: require.resolve('postcss-loader'),
options: {
postcssOptions: {
plugins: [(0, _autoprefixer.default)(), (0, _postcssPresetEnv.default)()]
}
}
}];
return cssExtractOptions === false ? loaders : [miniCssExtractPluginLoader, ...loaders];
};
const getSASSLoaders = ({
sassResources,
sassOptions
}) => {
const loaders = [{
loader: require.resolve('sass-loader'),
options: {
sassOptions
}
}];
if (sassResources) {
loaders.push({
loader: require.resolve('sass-resources-loader'),
options: {
resources: sassResources
}
});
}
return loaders;
};
function getStyleRules({
rootPath,
basePath = 'src',
libraryInclude = (0, _ramda.always)(false),
libraryExclude = (0, _ramda.always)(false),
cssModulesOptions = {},
sassOptions = {
outputStyle: 'expanded'
},
sassResources,
globalStyleDir,
mode,
target,
cssExtractOptions
}) {
const absoluteBasePath = _path.default.join(rootPath, basePath);
const cssLoaders = getCSSLoaders({
mode,
target,
cssExtractOptions
});
const cssModuleLoaders = cssLoaders.map(loader => {
if (/($|\/)css-loader/.test(loader.loader)) {
return {
...loader,
options: {
...loader.options,
modules: {
exportLocalsConvention: 'camelCase',
...(process.env.NODE_ENV === 'testing' ? {
localIdentName: '[name]__[local]'
} : {}),
...cssModulesOptions
}
}
};
}
return loader;
});
// we don't need to find it if they specified the directory
let foundSass = sassOptions?.implementation;
try {
if (!foundSass) foundSass = require.resolve('sass') || require.resolve('sass-embedded');
} catch (e) {
foundSass = sassOptions?.implementation;
if (sassOptions !== false) {
console.warn('`sass` or `sass-embedded` packages not found. SASS cannot be used.');
}
}
const sassLoaders = sassOptions === false || !foundSass ? [] : getSASSLoaders({
sassResources,
sassOptions
});
const excludeCSSProcess = [libraryExclude];
// global styles
if (globalStyleDir !== false) {
const globalStyleRegex = new RegExp(`${globalStyleDir}/`);
excludeCSSProcess.unshift(globalStyleRegex);
}
return {
test: /\.s?css$/i,
oneOf: [
// css modules (local styles)
sassOptions !== false && {
test: /\.scss$/i,
include: [absoluteBasePath, libraryInclude],
exclude: excludeCSSProcess,
use: [...cssModuleLoaders, ...sassLoaders]
},
// css-in-js like linaria do not use css-modules
{
test: /\.wyw-in-js\.css$/i,
include: [absoluteBasePath, libraryInclude],
exclude: excludeCSSProcess,
use: cssLoaders
},
// plain css as css-modules
{
test: /\.css$/i,
include: [absoluteBasePath, /\.storybook/, libraryInclude],
exclude: [...excludeCSSProcess, /\.wyw-in-js\.css$/i],
use: cssModuleLoaders
},
// global styles
globalStyleDir !== false && {
test: sassOptions === false ? /\.css$/i : /\.s?css$/i,
include: [absoluteBasePath],
exclude: [sassOptions === false ? /\.module\.css$/i : /\.module\.s?css$/i, new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`)],
use: [...cssLoaders, ...sassLoaders],
// Don't consider CSS imports dead code even if the
// containing package claims to have no side effects.
// Remove this when webpack adds a warning or an error for this.
// See https://github.com/webpack/webpack/issues/6571
sideEffects: true
}, globalStyleDir !== false && {
test: sassOptions === false ? /\.module\.css$/i : /\.module\.s?css$/i,
include: [absoluteBasePath],
exclude: [new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`)],
use: [...cssModuleLoaders, ...sassLoaders]
},
// css-in-js like linaria do not use css-modules - 3beta.14 and below
{
test: /\.css$/i,
include: [/node_modules\/\.cache/],
exclude: [absoluteBasePath, libraryInclude],
use: cssLoaders
},
// package css
{
test: /\.css$/i,
include: [/node_modules/],
use: cssModuleLoaders.slice(0, -1).map(loader => {
if (/($|\/)css-loader/.test(loader.loader)) {
return {
...loader,
options: {
...loader.options,
modules: {
...loader.options.modules,
auto: true,
...cssModulesOptions
}
}
};
}
return loader;
}),
// Don't consider CSS imports dead code even if the
// containing package claims to have no side effects.
// Remove this when webpack adds a warning or an error for this.
// See https://github.com/webpack/webpack/issues/6571
sideEffects: !target?.includes?.('node')
}].filter(rule => rule)
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_autoprefixer","_interopRequireDefault","require","_miniCssExtractPlugin","_path","_postcssPresetEnv","_ramda","getCSSLoaders","mode","target","cssExtractOptions","miniCssExtractPluginLoader","loader","MiniCssExtractPlugin","options","emit","includes","loaders","resolve","sourceMap","importLoaders","modules","postcssOptions","plugins","autoprefixer","cssPresetEnv","getSASSLoaders","sassResources","sassOptions","push","resources","getStyleRules","rootPath","basePath","libraryInclude","always","libraryExclude","cssModulesOptions","outputStyle","globalStyleDir","absoluteBasePath","path","join","cssLoaders","cssModuleLoaders","map","test","exportLocalsConvention","process","env","NODE_ENV","localIdentName","foundSass","implementation","e","console","warn","sassLoaders","excludeCSSProcess","globalStyleRegex","RegExp","unshift","oneOf","include","exclude","use","sideEffects","slice","auto","filter","rule"],"sources":["../../src/base/css.js"],"sourcesContent":["import autoprefixer from 'autoprefixer';\nimport MiniCssExtractPlugin from 'mini-css-extract-plugin';\nimport path from 'path';\nimport cssPresetEnv from 'postcss-preset-env';\nimport { always } from 'ramda';\n\nconst getCSSLoaders = ({ mode, target, cssExtractOptions }) => {\n  const miniCssExtractPluginLoader = {\n    loader: MiniCssExtractPlugin.loader,\n    options: { emit: !target?.includes?.('node') },\n  };\n\n  const loaders = [\n    {\n      loader: require.resolve('css-loader'),\n      options:\n        mode === 'development' ?\n          {\n            sourceMap: true,\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          }\n        : {\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          },\n    },\n    {\n      loader: require.resolve('postcss-loader'),\n      options: {\n        postcssOptions: {\n          plugins: [autoprefixer(), cssPresetEnv()],\n        },\n      },\n    },\n  ];\n\n  return cssExtractOptions === false ? loaders : (\n      [miniCssExtractPluginLoader, ...loaders]\n    );\n};\n\nconst getSASSLoaders = ({ sassResources, sassOptions }) => {\n  const loaders = [\n    {\n      loader: require.resolve('sass-loader'),\n      options: { sassOptions },\n    },\n  ];\n  if (sassResources) {\n    loaders.push({\n      loader: require.resolve('sass-resources-loader'),\n      options: {\n        resources: sassResources,\n      },\n    });\n  }\n  return loaders;\n};\n\nexport default function getStyleRules({\n  rootPath,\n  basePath = 'src',\n  libraryInclude = always(false),\n  libraryExclude = always(false),\n  cssModulesOptions = {},\n  sassOptions = { outputStyle: 'expanded' },\n  sassResources,\n  globalStyleDir,\n  mode,\n  target,\n  cssExtractOptions,\n}) {\n  const absoluteBasePath = path.join(rootPath, basePath);\n  const cssLoaders = getCSSLoaders({ mode, target, cssExtractOptions });\n  const cssModuleLoaders = cssLoaders.map(loader => {\n    if (/($|\\/)css-loader/.test(loader.loader)) {\n      return {\n        ...loader,\n        options: {\n          ...loader.options,\n          modules: {\n            exportLocalsConvention: 'camelCase',\n            ...(process.env.NODE_ENV === 'testing' ?\n              { localIdentName: '[name]__[local]' }\n            : {}),\n            ...cssModulesOptions,\n          },\n        },\n      };\n    }\n    return loader;\n  });\n  // we don't need to find it if they specified the directory\n  let foundSass = sassOptions?.implementation;\n  try {\n    if (!foundSass)\n      foundSass = require.resolve('sass') || require.resolve('sass-embedded');\n  } catch (e) {\n    foundSass = sassOptions?.implementation;\n    if (sassOptions !== false) {\n      console.warn(\n        '`sass` or `sass-embedded` packages not found. SASS cannot be used.',\n      );\n    }\n  }\n  const sassLoaders =\n    sassOptions === false || !foundSass ?\n      []\n    : getSASSLoaders({ sassResources, sassOptions });\n  const excludeCSSProcess = [libraryExclude];\n\n  // global styles\n  if (globalStyleDir !== false) {\n    const globalStyleRegex = new RegExp(`${globalStyleDir}/`);\n    excludeCSSProcess.unshift(globalStyleRegex);\n  }\n  return {\n    test: /\\.s?css$/i,\n    oneOf: [\n      // css modules (local styles)\n      sassOptions !== false && {\n        test: /\\.scss$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules\n      {\n        test: /\\.wyw-in-js\\.css$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: cssLoaders,\n      },\n      // plain css as css-modules\n      {\n        test: /\\.css$/i,\n        include: [absoluteBasePath, /\\.storybook/, libraryInclude],\n        exclude: [...excludeCSSProcess, /\\.wyw-in-js\\.css$/i],\n        use: cssModuleLoaders,\n      },\n      // global styles\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.css$/i : /\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [\n          sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n          new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`),\n        ],\n        use: [...cssLoaders, ...sassLoaders],\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: true,\n      },\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`)],\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules - 3beta.14 and below\n      {\n        test: /\\.css$/i,\n        include: [/node_modules\\/\\.cache/],\n        exclude: [absoluteBasePath, libraryInclude],\n        use: cssLoaders,\n      },\n      // package css\n      {\n        test: /\\.css$/i,\n        include: [/node_modules/],\n        use: cssModuleLoaders.slice(0, -1).map(loader => {\n          if (/($|\\/)css-loader/.test(loader.loader)) {\n            return {\n              ...loader,\n              options: {\n                ...loader.options,\n                modules: {\n                  ...loader.options.modules,\n                  auto: true,\n                  ...cssModulesOptions,\n                },\n              },\n            };\n          }\n          return loader;\n        }),\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: !target?.includes?.('node'),\n      },\n    ].filter(rule => rule),\n  };\n}\n"],"mappings":"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","ignoreList":[]}