2018-05-01 00:30:07 +03:00
|
|
|
const {isAbsolute} = require('path')
|
2018-04-26 23:44:58 +03:00
|
|
|
const cssstats = require('cssstats')
|
2018-04-28 01:31:41 +03:00
|
|
|
const fse = require('fs-extra')
|
2018-05-01 00:23:23 +03:00
|
|
|
const nodeSassImport = require('node-sass-import')
|
2018-04-28 01:31:41 +03:00
|
|
|
const postcss = require('postcss')
|
2018-05-01 00:23:23 +03:00
|
|
|
const promisify = require('pify')
|
2018-04-28 01:31:41 +03:00
|
|
|
const sass = require('node-sass')
|
2018-05-01 00:23:23 +03:00
|
|
|
|
2018-05-01 00:09:21 +03:00
|
|
|
const sassRender = promisify(sass.render)
|
2018-04-28 01:31:41 +03:00
|
|
|
|
2018-05-01 00:23:23 +03:00
|
|
|
function arrayify(value) {
|
|
|
|
return Array.isArray(value) ? value : [value]
|
|
|
|
}
|
2018-05-01 00:09:21 +03:00
|
|
|
|
2018-05-01 01:19:11 +03:00
|
|
|
module.exports = (src, flags = {}) => {
|
2018-04-28 01:31:41 +03:00
|
|
|
|
|
|
|
const cwd = process.cwd()
|
2018-05-01 00:30:07 +03:00
|
|
|
const sourceFile = isAbsolute(src) ? src : `${cwd}/${src}`
|
2018-04-28 01:31:41 +03:00
|
|
|
const outputDir = flags.outputDir || `${cwd}/build`
|
|
|
|
const outputFile = flags.output || `${outputDir}/build.css`
|
|
|
|
const outputJSFile = flags.outputJS || `${outputDir}/index.js`
|
|
|
|
const outputDataFile = flags.outputData || `${outputDir}/data.json`
|
|
|
|
|
2018-05-01 00:09:21 +03:00
|
|
|
const sassOptions = {
|
|
|
|
file: sourceFile,
|
|
|
|
outputStyle: flags.outputStyle || 'compressed',
|
|
|
|
importer: nodeSassImport,
|
|
|
|
includePaths: arrayify(flags.include)
|
|
|
|
}
|
|
|
|
|
2018-05-01 00:23:23 +03:00
|
|
|
// console.warn('sass options:', sassOptions)
|
2018-05-01 00:09:21 +03:00
|
|
|
|
2018-04-28 01:31:41 +03:00
|
|
|
return fse.mkdirp(outputDir)
|
2018-05-01 00:23:23 +03:00
|
|
|
.then(() => sassRender(sassOptions))
|
2018-04-28 01:31:41 +03:00
|
|
|
.then(({css}) => {
|
|
|
|
function postcssPlugins() {
|
|
|
|
const postcssrc = (() => {
|
|
|
|
if (flags.postcssconfig && fse.existsSync(`${cwd}/${flags.postcssconfig}`)) {
|
|
|
|
return require(`${cwd}/${flags.postcssconfig}`)
|
|
|
|
} else if (fse.existsSync(`${cwd}/.postcss.json`)) {
|
|
|
|
return require(`${cwd}/.postcss.json`)
|
|
|
|
} else {
|
|
|
|
return require('./.postcss.json')
|
|
|
|
}
|
|
|
|
})()
|
|
|
|
return postcssrc.use.map(name => {
|
|
|
|
return require(name)(postcssrc[name])
|
|
|
|
})
|
2018-04-26 23:44:58 +03:00
|
|
|
}
|
2018-04-28 01:31:41 +03:00
|
|
|
return postcss(postcssPlugins())
|
|
|
|
.process(css, {
|
|
|
|
from: sourceFile,
|
|
|
|
to: outputFile
|
|
|
|
})
|
|
|
|
})
|
|
|
|
.then(result => {
|
|
|
|
const data = {
|
|
|
|
cssstats: cssstats(result.css)
|
|
|
|
}
|
|
|
|
const json = JSON.stringify(data)
|
|
|
|
|
|
|
|
return Promise.all([
|
|
|
|
fse.writeFile(outputFile, result.css),
|
|
|
|
fse.writeFile(outputJSFile, `module.exports = ${json}`),
|
|
|
|
fse.writeFile(outputDataFile, json)
|
|
|
|
])
|
|
|
|
.then(() => [outputFile, outputJSFile, outputDataFile])
|
2018-04-26 23:44:58 +03:00
|
|
|
})
|
|
|
|
}
|