-
Notifications
You must be signed in to change notification settings - Fork 9
/
less-builder.js
57 lines (44 loc) · 1.64 KB
/
less-builder.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
var fs = System._nodeRequire('fs');
var less = require('npm:less/lib/less/index')()
function escape(source) {
return source
.replace(/(["\\])/g, '\\$1')
.replace(/[\f]/g, "\\f")
.replace(/[\b]/g, "\\b")
.replace(/[\n]/g, "\\n")
.replace(/[\t]/g, "\\t")
.replace(/[\r]/g, "\\r")
.replace(/[\u2028]/g, "\\u2028")
.replace(/[\u2029]/g, "\\u2029");
}
var cssInject = "(function(c){var d=document,a='appendChild',i='styleSheet',s=d.createElement('style');s.type='text/css';d.getElementsByTagName('head')[0][a](s);s[i]?s[i].cssText=c:s[a](d.createTextNode(c));})";
module.exports = function bundle(loads, opts) {
var loader = this;
var stubDefines = loads.map(function(load) {
return "System\.register('" + load.name + "', [], false, function() {});";
}).join('\n');
var lessOutput = loads.map(function(load) {
return load.source;
}).reduce(function(sourceA, sourceB) {
return sourceA + sourceB;
}, '');
return loader['import']('clean-css').then(function(CleanCSS){
return new Promise(function(resolve, reject) {
less.render(lessOutput,{compress: true}).then(function(data){
var cssOutput = data.css;
// write a separate CSS file if necessary
if (this.separateCSS) {
fs.writeFileSync(opts.outFile.replace(/\.js$/, '.css'), cssOutput);
return stubDefines;
}
resolve([stubDefines, cssInject, '("' + escape(cssOutput) + '");'].join('\n'))
},reject);
});
},
function(err) {
if (err.toString().indexOf('ENOENT') != -1)
throw new Error('Install Clean CSS via `jspm install npm:clean-css --dev` for CSS build support. Set System.buildCSS = false to skip CSS builds.');
throw err;
}
);
}