12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- // @ts-nocheck
- 'use strict';
- const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule');
- const isStandardSyntaxSelector = require('../../utils/isStandardSyntaxSelector');
- const keywordSets = require('../../reference/keywordSets');
- const parseSelector = require('../../utils/parseSelector');
- const report = require('../../utils/report');
- const ruleMessages = require('../../utils/ruleMessages');
- const validateOptions = require('../../utils/validateOptions');
- const ruleName = 'selector-pseudo-class-case';
- const messages = ruleMessages(ruleName, {
- expected: (actual, expected) => `Expected "${actual}" to be "${expected}"`,
- });
- function rule(expectation, options, context) {
- return (root, result) => {
- const validOptions = validateOptions(result, ruleName, {
- actual: expectation,
- possible: ['lower', 'upper'],
- });
- if (!validOptions) {
- return;
- }
- root.walkRules((rule) => {
- if (!isStandardSyntaxRule(rule)) {
- return;
- }
- const selector = rule.selector;
- if (!selector.includes(':')) {
- return;
- }
- const fixedSelector = parseSelector(
- rule.raws.selector ? rule.raws.selector.raw : rule.selector,
- result,
- rule,
- (selectorTree) => {
- selectorTree.walkPseudos((pseudoNode) => {
- const pseudo = pseudoNode.value;
- if (!isStandardSyntaxSelector(pseudo)) {
- return;
- }
- if (
- pseudo.includes('::') ||
- keywordSets.levelOneAndTwoPseudoElements.has(pseudo.toLowerCase().slice(1))
- ) {
- return;
- }
- const expectedPseudo =
- expectation === 'lower' ? pseudo.toLowerCase() : pseudo.toUpperCase();
- if (pseudo === expectedPseudo) {
- return;
- }
- if (context.fix) {
- pseudoNode.value = expectedPseudo;
- return;
- }
- report({
- message: messages.expected(pseudo, expectedPseudo),
- node: rule,
- index: pseudoNode.sourceIndex,
- ruleName,
- result,
- });
- });
- },
- );
- if (context.fix) {
- if (rule.raws.selector) {
- rule.raws.selector.raw = fixedSelector;
- } else {
- rule.selector = fixedSelector;
- }
- }
- });
- };
- }
- rule.ruleName = ruleName;
- rule.messages = messages;
- module.exports = rule;
|