forked from rbalicki2/gulp-json-sass
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
97 lines (79 loc) · 2.86 KB
/
index.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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
var through = require('through'),
chalk = require('chalk'),
gulpmatch = require('gulp-match'),
path = require('path'),
gutil = require('gulp-util');
// from http://stackoverflow.com/questions/17191265/legal-characters-for-sass-and-scss-variable-names
var escapableCharactersRegex = /(["!#$%&\'()*+,.\/:;\s<=>?@\[\]^\{\}|~])/g;
function replaceEscapableCharacters(str) {
return str.replace(escapableCharactersRegex, function(a,b) {
return '\\' + b;
});
}
var firstCharacterIsNumber = /^[0-9]/;
module.exports = function(opt) {
opt = opt || {};
opt.delim = opt.delim || '-';
opt.eol = ';';
opt.format = opt.format || 'css';
opt.ignoreJsonErrors = !!opt.ignoreJsonErrors;
opt.escapeIllegalCharacters = opt.escapeIllegalCharacters === undefined ? true : opt.escapeIllegalCharacters;
opt.firstCharacter = opt.firstCharacter || '_';
opt.prefixFirstNumericCharacter = opt.prefixFirstNumericCharacter === undefined ? true : opt.prefixFirstNumericCharacter;
return through(processJSON);
/////////////
function processJSON(file) {
// if it does not have a .json suffix, ignore the file
if (!gulpmatch(file,'**/*.json')) {
this.push(file);
return;
}
// load the JSON
try {
var parsedJSON = JSON.parse(file.contents);
} catch (e) {
if (opt.ignoreJsonErrors) {
console.log(chalk.red('[gulp-json-css]') + ' Invalid JSON in ' + file.path + '. (Continuing.)');
} else {
console.log(chalk.red('[gulp-json-css]') + ' Invalid JSON in ' + file.path);
this.emit('error', e);
}
return;
}
// process the JSON
var variables = [];
loadVariablesRecursive(parsedJSON, '', function pushVariable(assignmentString) {
variables.push(assignmentString);
});
var styles = variables.join('\n');
if(opt.format.toLowerCase() === 'css') {
file.contents = Buffer(':root {\n' + styles + '\n}');
file.path = gutil.replaceExtension(file.path, '.css');
} else {
file.contents = Buffer(styles);
file.path = gutil.replaceExtension(file.path, '.scss');
}
this.push(file);
}
function loadVariablesRecursive(obj, path, cb) {
var prefix = opt.format.toLowerCase() === 'css' ? '\t--' : '$';
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
var val = obj[key];
// escape invalid sass characters
if (opt.escapeIllegalCharacters) {
key = replaceEscapableCharacters(key);
}
// sass variables cannot begin with a number
if (path === '' && firstCharacterIsNumber.exec(key) && opt.prefixFirstNumericCharacter) {
key = opt.firstCharacter + key;
}
if (typeof val !== 'object') {
cb(prefix + path + key + ': ' + val + opt.eol);
} else {
loadVariablesRecursive(val, path + key + opt.delim, cb);
}
}
}
}
}