UNPKG

parcel-bundler

Version:

<p align="center"> <a href="https://parceljs.org/" target="_blank"> <img alt="Parcel" src="https://user-images.githubusercontent.com/19409/31321658-f6aed0f2-ac3d-11e7-8100-1587e676e0ec.png" width="749"> </a> </p>

61 lines (49 loc) 1.49 kB
const localRequire = require('../utils/localRequire'); const loadPlugins = require('../utils/loadPlugins'); const postcss = require('postcss'); const Config = require('../utils/config'); 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 Config.load(asset.name, [ '.postcssrc', '.postcssrc.js', 'postcss.config.js' ])); if (!config && !asset.options.minify) { 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) { let postcssModules = await localRequire('postcss-modules', asset.name); config.plugins.push(postcssModules(postcssModulesConfig)); } if (asset.options.minify) { config.plugins.push(cssnano()); } config.from = asset.name; config.to = asset.name; return config; }