UNPKG

935 BJavaScriptView Raw
1import postcss from 'postcss';
2
3const mediaRegExp = /^media$/i;
4const prefersInterfaceRegExp = /\(\s*prefers-color-scheme\s*:\s*(dark|light|no-preference)\s*\)/i;
5const colorIndexByStyle = {
6 dark: 48,
7 light: 70,
8 'no-preference': 22
9};
10
11const prefersInterfaceReplacer = ($0, style) => `(color-index: ${colorIndexByStyle[style.toLowerCase()]})`;
12
13var postcss$1 = postcss.plugin('postcss-prefers-color-scheme', opts => {
14 const preserve = 'preserve' in Object(opts) ? opts.preserve : true;
15 return root => {
16 root.walkAtRules(mediaRegExp, atRule => {
17 const params = atRule.params;
18 const altParams = params.replace(prefersInterfaceRegExp, prefersInterfaceReplacer);
19
20 if (params !== altParams) {
21 if (preserve) {
22 atRule.cloneBefore({
23 params: altParams
24 });
25 } else {
26 atRule.params = altParams;
27 }
28 }
29 });
30 };
31});
32
33export default postcss$1;