UNPKG

stylelint

Version:

A mighty CSS linter that helps you avoid errors and enforce conventions.

102 lines (79 loc) 2.52 kB
// NOTICE: This file is generated by Rollup. To modify it, // please instead edit the ESM counterpart and rebuild with Rollup (npm run build). 'use strict'; const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule.cjs'); const selectors = require('../../reference/selectors.cjs'); const parseSelector = require('../../utils/parseSelector.cjs'); const report = require('../../utils/report.cjs'); const ruleMessages = require('../../utils/ruleMessages.cjs'); const validateOptions = require('../../utils/validateOptions.cjs'); const ruleName = 'selector-pseudo-element-colon-notation'; const messages = ruleMessages(ruleName, { expected: (q) => `Expected ${q} colon pseudo-element notation`, }); const meta = { url: 'https://stylelint.io/user-guide/rules/selector-pseudo-element-colon-notation', fixable: true, }; /** @type {import('stylelint').Rule} */ const rule = (primary, _secondaryOptions, context) => { return (root, result) => { const validOptions = validateOptions(result, ruleName, { actual: primary, possible: ['single', 'double'], }); if (!validOptions) { return; } let fixedColon = ''; if (primary === 'single') { fixedColon = ':'; } else if (primary === 'double') { fixedColon = '::'; } root.walkRules((ruleNode) => { if (!isStandardSyntaxRule(ruleNode)) { return; } const selector = ruleNode.selector; // get out early if no pseudo elements or classes if (!selector.includes(':')) { return; } const fixedSelector = parseSelector(selector, result, ruleNode, (selectors$1) => { selectors$1.walkPseudos((pseudo) => { const pseudoElement = pseudo.value.replaceAll(':', ''); if (!selectors.levelOneAndTwoPseudoElements.has(pseudoElement.toLowerCase())) { return; } const isDouble = pseudo.value.startsWith('::'); if (primary === 'single' && !isDouble) { return; } if (primary === 'double' && isDouble) { return; } if (context.fix) { pseudo.replaceWith(pseudo.clone({ value: fixedColon + pseudoElement })); return; } report({ message: messages.expected(primary), node: ruleNode, index: pseudo.sourceIndex, endIndex: pseudo.sourceIndex + (isDouble ? 2 : 1), result, ruleName, }); }); }); if (context.fix && fixedSelector) { ruleNode.selector = fixedSelector; } }); }; }; rule.ruleName = ruleName; rule.messages = messages; rule.meta = meta; module.exports = rule;