index.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. 'use strict';
  2. const isStandardSyntaxSelector = require('../../utils/isStandardSyntaxSelector');
  3. const report = require('../../utils/report');
  4. const ruleMessages = require('../../utils/ruleMessages');
  5. const validateOptions = require('../../utils/validateOptions');
  6. const ruleName = 'keyframe-block-no-duplicate-selectors';
  7. const messages = ruleMessages(ruleName, {
  8. rejected: (selector) => `Unexpected duplicate "${selector}"`,
  9. });
  10. const meta = {
  11. url: 'https://stylelint.io/user-guide/rules/list/keyframe-block-no-duplicate-selectors',
  12. };
  13. /** @type {import('stylelint').Rule} */
  14. const rule = (primary) => {
  15. return (root, result) => {
  16. const validOptions = validateOptions(result, ruleName, { actual: primary });
  17. if (!validOptions) {
  18. return;
  19. }
  20. root.walkAtRules(/^(-(moz|webkit)-)?keyframes$/i, (atRuleKeyframes) => {
  21. const selectors = new Set();
  22. atRuleKeyframes.walkRules((keyframeRule) => {
  23. const ruleSelectors = keyframeRule.selectors;
  24. ruleSelectors.forEach((selector) => {
  25. if (!isStandardSyntaxSelector(selector)) {
  26. return;
  27. }
  28. const normalizedSelector = selector.toLowerCase();
  29. const isDuplicate = selectors.has(normalizedSelector);
  30. if (isDuplicate) {
  31. report({
  32. message: messages.rejected(selector),
  33. node: keyframeRule,
  34. result,
  35. ruleName,
  36. word: selector,
  37. });
  38. return;
  39. }
  40. selectors.add(normalizedSelector);
  41. });
  42. });
  43. });
  44. };
  45. };
  46. rule.ruleName = ruleName;
  47. rule.messages = messages;
  48. rule.meta = meta;
  49. module.exports = rule;