This repository has been archived by the owner on Jan 28, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
index.js
59 lines (49 loc) · 1.74 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
const cssom = require('cssom');
const os = require('os');
const CSSFontFaceRule = require('cssom/lib/CSSFontFaceRule').CSSFontFaceRule;
/**
* Returns Media Query text for a CSS source.
*
* @param {String} css source
* @api public
*/
module.exports = css => {
const rules = cssom.parse(css).cssRules || [];
const queries = [];
let queryMedia;
let queryString;
let style;
let property;
let value;
let important;
let result;
rules.forEach(({type, media, cssRules}) => {
/* CSS types
STYLE: 1,
IMPORT: 3,
MEDIA: 4,
FONT_FACE: 5,
*/
if (type === cssom.CSSMediaRule.prototype.type) {
queryMedia = Array.prototype.slice.call(media).join(', ');
queryString = [];
queryString.push(`${os.EOL}@media ${queryMedia} {`);
cssRules.forEach(rule => {
if (rule.type === cssom.CSSStyleRule.prototype.type || rule.type === CSSFontFaceRule.prototype.type) {
queryString.push(` ${rule.type === cssom.CSSStyleRule.prototype.type ? rule.selectorText : '@font-face'} {`);
for (style = 0; style < rule.style.length; style++) {
property = rule.style[style];
value = rule.style[property];
important = rule.style._importants[property] ? ' !important' : '';
queryString.push(` ${property}: ${value}${important};`);
}
queryString.push(' }');
}
});
queryString.push('}');
result = queryString.length ? queryString.join(os.EOL) + os.EOL : '';
queries.push(result);
}
});
return queries.join(os.EOL);
};