UNPKG

parcel-bundler

Version:

Blazing fast, zero configuration web application bundler

73 lines (60 loc) 1.93 kB
const localRequire = require('../utils/localRequire'); const loadPlugins = require('../utils/loadPlugins'); const postcss = require('postcss'); const cssnano = require('cssnano'); module.exports = async function(asset) { let config = await getConfig(asset); if (!config) { return; } await asset.parseIfNeeded(); let res = await postcss(config.plugins).process(asset.getCSSAst(), config); asset.ast.css = res.css; asset.ast.dirty = false; }; async function getConfig(asset) { let config = asset.package.postcss || (await asset.getConfig([ '.postcssrc', '.postcssrc.js', 'postcss.config.js' ])); let enableModules = asset.options.rendition && asset.options.rendition.modules; if (!config && !asset.options.minify && !enableModules) { return; } config = config || {}; let postcssModulesConfig = { getJSON: (filename, json) => (asset.cssModules = json) }; if (config.plugins && config.plugins['postcss-modules']) { postcssModulesConfig = Object.assign( config.plugins['postcss-modules'], postcssModulesConfig ); delete config.plugins['postcss-modules']; } config.plugins = await loadPlugins(config.plugins, asset.name); if (config.modules || enableModules) { let postcssModules = await localRequire('postcss-modules', asset.name); config.plugins.push(postcssModules(postcssModulesConfig)); } if (asset.options.minify) { config.plugins.push( cssnano( (await asset.getConfig(['cssnano.config.js'])) || { // Only enable safe css transforms by default. // See: https://github.com/parcel-bundler/parcel/issues/698 // Note: Remove when upgrading cssnano to v4 // See: https://github.com/ben-eb/cssnano/releases/tag/v4.0.0-rc.0 safe: true } ) ); } config.from = asset.name; config.to = asset.name; return config; }