diff options
| author | ruki <waruqi@gmail.com> | 2018-11-08 00:38:48 +0800 |
|---|---|---|
| committer | ruki <waruqi@gmail.com> | 2018-11-07 21:53:09 +0800 |
| commit | 26105034da4fcce7ac883c899d781f016559310d (patch) | |
| tree | c459a5dc4e3aa0972d9919033ece511ce76dd129 /node_modules/postcss-calc/index.js | |
| parent | 2c77f00f1a7ecb6c8192f9c16d3b2001b254a107 (diff) | |
| download | xmake-docs-26105034da4fcce7ac883c899d781f016559310d.tar.gz xmake-docs-26105034da4fcce7ac883c899d781f016559310d.zip | |
switch to vuepress
Diffstat (limited to 'node_modules/postcss-calc/index.js')
| -rwxr-xr-x | node_modules/postcss-calc/index.js | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/node_modules/postcss-calc/index.js b/node_modules/postcss-calc/index.js new file mode 100755 index 00000000..f0791b15 --- /dev/null +++ b/node_modules/postcss-calc/index.js @@ -0,0 +1,62 @@ +/** + * Module dependencies. + */ +var reduceCSSCalc = require("reduce-css-calc") +var helpers = require("postcss-message-helpers") +var postcss = require("postcss") + +var CONTAINS_CALC = /\bcalc\([\s\S]*?\)/ + +/** + * PostCSS plugin to reduce calc() function calls. + */ +module.exports = postcss.plugin("postcss-calc", function(options) { + options = options || {} + var precision = options.precision + var preserve = options.preserve + var warnWhenCannotResolve = options.warnWhenCannotResolve + var mediaQueries = options.mediaQueries + var selectors = options.selectors + + return function(style, result) { + function transformValue(node, property) { + var value = node[property] + + if (!value || !CONTAINS_CALC.test(value)) { + return + } + + helpers.try(function transformCSSCalc() { + var reducedValue = reduceCSSCalc(value, precision) + + if (warnWhenCannotResolve && CONTAINS_CALC.test(reducedValue)) { + result.warn("Could not reduce expression: " + value, + {plugin: "postcss-calc", node: node}) + } + + if (!preserve) { + node[property] = reducedValue + return + } + + if (reducedValue != value) { + var clone = node.clone() + clone[property] = reducedValue + node.parent.insertBefore(node, clone) + } + }, node.source) + } + + style.walk(function(rule) { + if (mediaQueries && rule.type === "atrule") { + return transformValue(rule, "params") + } + else if (rule.type === "decl") { + return transformValue(rule, "value") + } + else if (selectors && rule.type === "rule") { + return transformValue(rule, "selector") + } + }) + } +}) |
