Sha256: 620401c578282cf9c0f8e93b91eb72ab992b0a1685c61599c82ac8a4ae518d97
Contents?: true
Size: 1.59 KB
Versions: 23
Compression:
Stored size: 1.59 KB
Contents
'use strict'; const _ = require('lodash'); const isAutoprefixable = require('../../utils/isAutoprefixable'); const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule'); const optionsMatches = require('../../utils/optionsMatches'); const parseSelector = require('../../utils/parseSelector'); const report = require('../../utils/report'); const ruleMessages = require('../../utils/ruleMessages'); const validateOptions = require('../../utils/validateOptions'); const ruleName = 'selector-no-vendor-prefix'; const messages = ruleMessages(ruleName, { rejected: (selector) => `Unexpected vendor-prefix "${selector}"`, }); function rule(actual, options) { return (root, result) => { const validOptions = validateOptions( result, ruleName, { actual }, { actual: options, possible: { ignoreSelectors: [_.isString], }, optional: true, }, ); if (!validOptions) { return; } root.walkRules((rule) => { if (!isStandardSyntaxRule(rule)) { return; } const selector = rule.selector; parseSelector(selector, result, rule, (selectorTree) => { selectorTree.walkPseudos((pseudoNode) => { if (isAutoprefixable.selector(pseudoNode.value)) { if (optionsMatches(options, 'ignoreSelectors', pseudoNode.value)) { return; } report({ result, ruleName, message: messages.rejected(pseudoNode.value), node: rule, index: (rule.raws.before || '').length + pseudoNode.sourceIndex, }); } }); }); }); }; } rule.ruleName = ruleName; rule.messages = messages; module.exports = rule;
Version data entries
23 entries across 23 versions & 1 rubygems