UNPKG

mpvue-loader

Version:

mpvue single-file component loader for Webpack

90 lines (85 loc) 2.96 kB
var postcss = require('postcss') var selectorParser = require('postcss-selector-parser') module.exports = postcss.plugin('add-id', function (opts) { return function (root) { var keyframes = Object.create(null) root.each(function rewriteSelector (node) { if (!node.selector) { // handle media queries if (node.type === 'atrule') { if (node.name === 'media' || node.name === 'supports') { node.each(rewriteSelector) } else if (node.name === 'keyframes') { // register keyframes keyframes[node.params] = node.params = node.params + '-' + opts.id } } return } node.selector = selectorParser(function (selectors) { selectors.each(function (selector) { var node = null selector.each(function (n) { // ">>>" combinator if (n.type === 'combinator' && n.value === '>>>') { n.value = ' ' n.spaces.before = n.spaces.after = '' return false } // /deep/ alias for >>>, since >>> doesn't work in SASS if (n.type === 'tag' && n.value === '/deep/') { var next = n.next() if (next.type === 'combinator' && next.value === ' ') { next.remove() } n.remove() return false } if (n.type !== 'pseudo' && n.type !== 'combinator') { node = n } }) selector.insertAfter(node, selectorParser.className({ value: opts.id })) // TODO, options for mp // selector.insertAfter(node, selectorParser.attribute({ // attribute: opts.id // })) // selector.prepend(selectorParser.className({ // value: `${opts.id} ` // })) }) }).process(node.selector).result }) // If keyframes are found in this <style>, find and rewrite animation names // in declarations. // Caveat: this only works for keyframes and animation rules in the same // <style> element. if (Object.keys(keyframes).length) { root.walkDecls(decl => { // individual animation-name declaration if (/-?animation-name$/.test(decl.prop)) { decl.value = decl.value.split(',') .map(v => keyframes[v.trim()] || v.trim()) .join(',') } // shorthand if (/-?animation$/.test(decl.prop)) { decl.value = decl.value.split(',') .map(v => { var vals = v.trim().split(/\s+/) var i = vals.findIndex(val => keyframes[val]) if (i !== -1) { vals.splice(i, 1, keyframes[vals[i]]) return vals.join(' ') } else { return v } }) .join(',') } }) } } })