| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 | 'use strict';Object.defineProperty(exports, "__esModule", {    value: true});var _postcss = require('postcss');var _postcssValueParser = require('postcss-value-parser');var _stylehacks = require('stylehacks');var _canMerge = require('../canMerge');var _canMerge2 = _interopRequireDefault(_canMerge);var _getDecls = require('../getDecls');var _getDecls2 = _interopRequireDefault(_getDecls);var _getValue = require('../getValue');var _getValue2 = _interopRequireDefault(_getValue);var _mergeRules = require('../mergeRules');var _mergeRules2 = _interopRequireDefault(_mergeRules);var _insertCloned = require('../insertCloned');var _insertCloned2 = _interopRequireDefault(_insertCloned);var _remove = require('../remove');var _remove2 = _interopRequireDefault(_remove);var _isCustomProp = require('../isCustomProp');var _isCustomProp2 = _interopRequireDefault(_isCustomProp);var _canExplode = require('../canExplode');var _canExplode2 = _interopRequireDefault(_canExplode);function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }const properties = ['column-width', 'column-count'];const auto = 'auto';const inherit = 'inherit';/** * Normalize a columns shorthand definition. Both of the longhand * properties' initial values are 'auto', and as per the spec, * omitted values are set to their initial values. Thus, we can * remove any 'auto' definition when there are two values. * * Specification link: https://www.w3.org/TR/css3-multicol/ */function normalize(values) {    if (values[0].toLowerCase() === auto) {        return values[1];    }    if (values[1].toLowerCase() === auto) {        return values[0];    }    if (values[0].toLowerCase() === inherit && values[1].toLowerCase() === inherit) {        return inherit;    }    return values.join(' ');}function explode(rule) {    rule.walkDecls(/^columns$/i, decl => {        if (!(0, _canExplode2.default)(decl)) {            return;        }        if ((0, _stylehacks.detect)(decl)) {            return;        }        let values = _postcss.list.space(decl.value);        if (values.length === 1) {            values.push(auto);        }        values.forEach((value, i) => {            let prop = properties[1];            if (value.toLowerCase() === auto) {                prop = properties[i];            } else if ((0, _postcssValueParser.unit)(value).unit) {                prop = properties[0];            }            (0, _insertCloned2.default)(decl.parent, decl, {                prop,                value            });        });        decl.remove();    });}function cleanup(rule) {    let decls = (0, _getDecls2.default)(rule, ['columns'].concat(properties));    while (decls.length) {        const lastNode = decls[decls.length - 1];        // remove properties of lower precedence        const lesser = decls.filter(node => !(0, _stylehacks.detect)(lastNode) && !(0, _stylehacks.detect)(node) && node !== lastNode && node.important === lastNode.important && lastNode.prop === 'columns' && node.prop !== lastNode.prop);        lesser.forEach(_remove2.default);        decls = decls.filter(node => !~lesser.indexOf(node));        // get duplicate properties        let duplicates = decls.filter(node => !(0, _stylehacks.detect)(lastNode) && !(0, _stylehacks.detect)(node) && node !== lastNode && node.important === lastNode.important && node.prop === lastNode.prop && !(!(0, _isCustomProp2.default)(node) && (0, _isCustomProp2.default)(lastNode)));        duplicates.forEach(_remove2.default);        decls = decls.filter(node => node !== lastNode && !~duplicates.indexOf(node));    }}function merge(rule) {    (0, _mergeRules2.default)(rule, properties, (rules, lastNode) => {        if ((0, _canMerge2.default)(rules) && !rules.some(_stylehacks.detect)) {            (0, _insertCloned2.default)(lastNode.parent, lastNode, {                prop: 'columns',                value: normalize(rules.map(_getValue2.default))            });            rules.forEach(_remove2.default);            return true;        }    });    cleanup(rule);}exports.default = {    explode,    merge};module.exports = exports['default'];
 |