Sha256: 27f0bfc2eddcf3749f48373f8c0ac546e6af9fc385afa6b016ca28838f7a7142
Contents?: true
Size: 1.58 KB
Versions: 23
Compression:
Stored size: 1.58 KB
Contents
'use strict'; const _ = require('lodash'); const isStandardSyntaxCombinator = require('../../utils/isStandardSyntaxCombinator'); const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule'); const parseSelector = require('../../utils/parseSelector'); const report = require('../../utils/report'); const ruleMessages = require('../../utils/ruleMessages'); const validateOptions = require('../../utils/validateOptions'); const ruleName = 'selector-combinator-blacklist'; const messages = ruleMessages(ruleName, { rejected: (combinator) => `Unexpected combinator "${combinator}"`, }); function rule(blacklist) { return (root, result) => { const validOptions = validateOptions(result, ruleName, { actual: blacklist, possible: [_.isString], }); if (!validOptions) { return; } root.walkRules((rule) => { if (!isStandardSyntaxRule(rule)) { return; } const selector = rule.selector; parseSelector(selector, result, rule, (fullSelector) => { fullSelector.walkCombinators((combinatorNode) => { if (!isStandardSyntaxCombinator(combinatorNode)) { return; } const value = normalizeCombinator(combinatorNode.value); if (!blacklist.includes(value)) { return; } report({ result, ruleName, message: messages.rejected(value), node: rule, index: combinatorNode.sourceIndex, }); }); }); }); }; } function normalizeCombinator(value) { return value.replace(/\s+/g, ' '); } rule.primaryOptionArray = true; rule.ruleName = ruleName; rule.messages = messages; module.exports = rule;
Version data entries
23 entries across 23 versions & 1 rubygems