2019-02-12 06:49:13 +03:00
|
|
|
#!/usr/bin/env node
|
|
|
|
const globby = require('globby')
|
|
|
|
const cssstats = require('cssstats')
|
|
|
|
const postcss = require('postcss')
|
|
|
|
const loadConfig = require('postcss-load-config')
|
2019-02-12 08:03:20 +03:00
|
|
|
const {remove, mkdirp, readFile, writeFile} = require('fs-extra')
|
2019-02-12 06:49:13 +03:00
|
|
|
const {dirname, basename, join} = require('path')
|
|
|
|
const {promisify} = require('util')
|
2019-01-29 01:52:45 +03:00
|
|
|
|
2019-02-12 06:49:13 +03:00
|
|
|
const inDir = 'src'
|
|
|
|
const outDir = 'dist'
|
2019-02-12 08:03:20 +03:00
|
|
|
const statsDir = join(outDir, 'stats')
|
2019-02-12 08:28:25 +03:00
|
|
|
const encoding = 'utf8'
|
2019-01-29 01:52:45 +03:00
|
|
|
|
2019-02-12 06:49:13 +03:00
|
|
|
remove(outDir)
|
2019-02-12 08:03:20 +03:00
|
|
|
.then(() => mkdirp(statsDir))
|
2019-02-12 06:49:13 +03:00
|
|
|
.then(() => globby([`${inDir}/**/index.scss`]))
|
|
|
|
.then(files => {
|
2019-02-12 08:03:20 +03:00
|
|
|
return loadConfig().then(({plugins, options}) => {
|
2019-02-12 06:49:13 +03:00
|
|
|
const processor = postcss(plugins)
|
|
|
|
|
|
|
|
const inPattern = new RegExp(`^${inDir}/`)
|
|
|
|
const names = {
|
|
|
|
'index.scss': 'primer'
|
|
|
|
}
|
2019-02-12 08:28:25 +03:00
|
|
|
const tasks = files.map(from => {
|
|
|
|
const path = from.replace(inPattern, '')
|
2019-02-12 06:49:13 +03:00
|
|
|
const name = names[path] || dirname(path).replace(/\//g, '-')
|
2019-02-12 08:03:20 +03:00
|
|
|
|
2019-02-12 08:28:25 +03:00
|
|
|
const to = join(outDir, `${name}.css`)
|
|
|
|
const info = {
|
|
|
|
name,
|
|
|
|
source: from,
|
|
|
|
sass: `@primer/css/${path}`,
|
|
|
|
css: to,
|
|
|
|
map: `${to}.map`,
|
|
|
|
js: join(outDir, `${name}.js`),
|
|
|
|
stats: join(statsDir, `${name}.json`),
|
|
|
|
legacy: `primer-${name}/index.scss`
|
|
|
|
}
|
2019-02-12 08:03:20 +03:00
|
|
|
|
2019-02-12 08:28:25 +03:00
|
|
|
return readFile(from)
|
|
|
|
.then(scss => processor.process(scss, Object.assign({from, to}, options)))
|
2019-02-12 06:49:13 +03:00
|
|
|
.then(result => Promise.all([
|
2019-02-12 08:28:25 +03:00
|
|
|
writeFile(to, result.css, encoding),
|
|
|
|
writeFile(info.stats, JSON.stringify(cssstats(result.css)), encoding),
|
|
|
|
writeFile(info.js, `module.exports = {cssstats: require('./stats/${name}.json')}`, encoding),
|
|
|
|
result.map ? writeFile(info.map, result.map, encoding) : null
|
2019-02-12 06:49:13 +03:00
|
|
|
]))
|
2019-02-12 08:28:25 +03:00
|
|
|
.then(() => info)
|
2019-02-12 06:49:13 +03:00
|
|
|
})
|
|
|
|
|
|
|
|
return Promise.all(tasks)
|
|
|
|
})
|
2019-02-12 08:28:25 +03:00
|
|
|
.then(files => {
|
|
|
|
const meta = {files}
|
|
|
|
return writeFile(join(outDir, 'meta.json'), JSON.stringify(meta, null, 2), encoding)
|
|
|
|
})
|
2019-02-12 06:49:13 +03:00
|
|
|
})
|
|
|
|
.catch(error => {
|
|
|
|
console.error(error)
|
|
|
|
process.exitCode = 1
|
|
|
|
})
|