UNPKG

1.68 kBJavaScriptView Raw
1// @ts-nocheck
2
3'use strict';
4
5const _ = require('lodash');
6const isStandardSyntaxRule = require('../../utils/isStandardSyntaxRule');
7const matchesStringOrRegExp = require('../../utils/matchesStringOrRegExp');
8const parseSelector = require('../../utils/parseSelector');
9const postcss = require('postcss');
10const report = require('../../utils/report');
11const ruleMessages = require('../../utils/ruleMessages');
12const validateOptions = require('../../utils/validateOptions');
13
14const ruleName = 'selector-pseudo-element-disallowed-list';
15
16const messages = ruleMessages(ruleName, {
17 rejected: (selector) => `Unexpected pseudo-element "${selector}"`,
18});
19
20function rule(list) {
21 return (root, result) => {
22 const validOptions = validateOptions(result, ruleName, {
23 actual: list,
24 possible: [_.isString, _.isRegExp],
25 });
26
27 if (!validOptions) {
28 return;
29 }
30
31 root.walkRules((rule) => {
32 if (!isStandardSyntaxRule(rule)) {
33 return;
34 }
35
36 const selector = rule.selector;
37
38 if (!selector.includes('::')) {
39 return;
40 }
41
42 parseSelector(selector, result, rule, (selectorTree) => {
43 selectorTree.walkPseudos((pseudoNode) => {
44 const value = pseudoNode.value;
45
46 // Ignore pseudo-classes
47 if (value[1] !== ':') {
48 return;
49 }
50
51 const name = value.slice(2);
52
53 if (!matchesStringOrRegExp(postcss.vendor.unprefixed(name), list)) {
54 return;
55 }
56
57 report({
58 index: pseudoNode.sourceIndex,
59 message: messages.rejected(name),
60 node: rule,
61 result,
62 ruleName,
63 });
64 });
65 });
66 });
67 };
68}
69
70rule.primaryOptionArray = true;
71
72rule.ruleName = ruleName;
73rule.messages = messages;
74module.exports = rule;