forked from Costava/solitaire
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild-css.js
70 lines (57 loc) · 1.33 KB
/
build-css.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
/**
* Pass -p option to this script to produce minified CSS instead
* Usage: node build-css.js
* node build-css.js -p
*/
const fs = require('fs');
var postcss = require('postcss');
////////// Config
var inputFile = './src/styles/style.css';
var outputLocation = './prep/final.css';
var outputLocationMin = './prep/final.min.css';
//////////
var minify = process.argv.indexOf('-p') != -1;
/**
* Returns a promise that handles the css
* @param {string} outputLocation
* @param {array of require calls} plugins
*/
function handleCSS(outputLocation, plugins) {
return new Promise(function(resolve, reject) {
fs.readFile(inputFile, 'utf-8', function(err, css) {
if (err) reject(err);
resolve(css);
});
})
.then(function(css) {
var processor = postcss(plugins);
return processor.process(css);
})
.then(function(result) {
return new Promise(function(resolve, reject) {
fs.writeFile(outputLocation, result.css, function(err) {
if (err) reject(err);
console.log(`Built ${inputFile} and outputted to ${outputLocation}`);
resolve();
});
});
});
}
if (minify) {
console.log("Minifying CSS");
handleCSS(
outputLocationMin,
[
require('postcss-advanced-variables'),
require('cssnano')
]
);
}
else {
handleCSS(
outputLocation,
[
require('postcss-advanced-variables')
]
);
}