UNPKG

@anansi/webpack-config

Version:
203 lines (201 loc) 22 kB
"use strict"; 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, hoistUseStatements: true } }); } 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 { 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","hoistUseStatements","getStyleRules","rootPath","basePath","libraryInclude","always","libraryExclude","cssModulesOptions","outputStyle","globalStyleDir","absoluteBasePath","path","join","cssLoaders","cssModuleLoaders","map","test","exportLocalsConvention","process","env","NODE_ENV","localIdentName","foundSass","implementation","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        hoistUseStatements: true,\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 {\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":[]}