|
|
"use strict";
Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0;
var _postcssSelectorParser = _interopRequireDefault(require("postcss-selector-parser"));
var _postcssValueParser = _interopRequireDefault(require("postcss-value-parser"));
var _parser = require("../parser");
var _reducer = _interopRequireDefault(require("./reducer"));
var _stringifier = _interopRequireDefault(require("./stringifier"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
// eslint-disable-next-line import/no-unresolved
var MATCH_CALC = /((?:-(moz|webkit)-)?calc)/i;
function transformValue(value, options, result, item) { return (0, _postcssValueParser.default)(value).walk(function (node) { // skip anything which isn't a calc() function
if (node.type !== 'function' || !MATCH_CALC.test(node.value)) { return node; } // stringify calc expression and produce an AST
var contents = _postcssValueParser.default.stringify(node.nodes);
var ast = _parser.parser.parse(contents); // reduce AST to its simplest form, that is, either to a single value
// or a simplified calc expression
var reducedAst = (0, _reducer.default)(ast, options.precision); // stringify AST and write it back
node.type = 'word'; node.value = (0, _stringifier.default)(node.value, reducedAst, value, options, result, item); return false; }).toString(); }
function transformSelector(value, options, result, item) { return (0, _postcssSelectorParser.default)(function (selectors) { selectors.walk(function (node) { // attribute value
// e.g. the "calc(3*3)" part of "div[data-size="calc(3*3)"]"
if (node.type === 'attribute' && node.value) { node.setValue(transformValue(node.value, options, result, item)); } // tag value
// e.g. the "calc(3*3)" part of "div:nth-child(2n + calc(3*3))"
if (node.type === 'tag') { node.value = transformValue(node.value, options, result, item); }
return; }); }).processSync(value); }
var _default = function _default(node, property, options, result) { var value = property === "selector" ? transformSelector(node[property], options, result, node) : transformValue(node[property], options, result, node); // if the preserve option is enabled and the value has changed, write the
// transformed value into a cloned node which is inserted before the current
// node, preserving the original value. Otherwise, overwrite the original
// value.
if (options.preserve && node[property] !== value) { var clone = node.clone(); clone[property] = value; node.parent.insertBefore(node, clone); } else { node[property] = value; } };
exports.default = _default; module.exports = exports.default;
|