1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- 'use strict';
- function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
- var postcss = _interopDefault(require('postcss'));
- var parser = _interopDefault(require('postcss-selector-parser'));
- const anyAnyLinkMatch = /:any-link/;
- var index = postcss.plugin('postcss-pseudo-class-any-link', opts => {
- const preserve = 'preserve' in Object(opts) ? Boolean(opts.preserve) : true;
- return root => {
-
- root.walkRules(anyAnyLinkMatch, rule => {
- const rawSelector = rule.raws.selector && rule.raws.selector.raw || rule.selector;
- if (rawSelector[rawSelector.length - 1] !== ':') {
-
- const updatedSelector = parser(selectors => {
-
- let node;
- let nodeIndex;
- let selector;
- let selectorLink;
- let selectorVisited;
- let selectorIndex = -1;
- while (selector = selectors.nodes[++selectorIndex]) {
-
- nodeIndex = -1;
- while (node = selector.nodes[++nodeIndex]) {
-
- if (node.value === ':any-link') {
-
- selectorLink = selector.clone();
- selectorVisited = selector.clone();
- selectorLink.nodes[nodeIndex].value = ':link';
- selectorVisited.nodes[nodeIndex].value = ':visited';
- selectors.nodes.splice(selectorIndex--, 1, selectorLink, selectorVisited);
- break;
- }
- }
- }
- }).processSync(rawSelector);
- if (updatedSelector !== rawSelector) {
- if (preserve) {
- rule.cloneBefore({
- selector: updatedSelector
- });
- } else {
- rule.selector = updatedSelector;
- }
- }
- }
- });
- };
- });
- module.exports = index;
|