index.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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/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,
  33. messageArgs: [selector],
  34. node: keyframeRule,
  35. result,
  36. ruleName,
  37. word: selector,
  38. });
  39. return;
  40. }
  41. selectors.add(normalizedSelector);
  42. });
  43. });
  44. });
  45. };
  46. };
  47. rule.ruleName = ruleName;
  48. rule.messages = messages;
  49. rule.meta = meta;
  50. module.exports = rule;