index.js 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. 'use strict';
  2. const atRuleParamIndex = require('../../utils/atRuleParamIndex');
  3. const isStandardSyntaxKeyframesName = require('../../utils/isStandardSyntaxKeyframesName');
  4. const report = require('../../utils/report');
  5. const ruleMessages = require('../../utils/ruleMessages');
  6. const validateOptions = require('../../utils/validateOptions');
  7. const { isRegExp, isString } = require('../../utils/validateTypes');
  8. const ruleName = 'keyframes-name-pattern';
  9. const messages = ruleMessages(ruleName, {
  10. expected: (keyframeName, pattern) =>
  11. `Expected keyframe name "${keyframeName}" to match pattern "${pattern}"`,
  12. });
  13. const meta = {
  14. url: 'https://stylelint.io/user-guide/rules/list/keyframes-name-pattern',
  15. };
  16. /** @type {import('stylelint').Rule} */
  17. const rule = (primary) => {
  18. return (root, result) => {
  19. const validOptions = validateOptions(result, ruleName, {
  20. actual: primary,
  21. possible: [isRegExp, isString],
  22. });
  23. if (!validOptions) {
  24. return;
  25. }
  26. const regex = isString(primary) ? new RegExp(primary) : primary;
  27. root.walkAtRules(/keyframes/i, (keyframesNode) => {
  28. const value = keyframesNode.params;
  29. if (!isStandardSyntaxKeyframesName(value)) {
  30. return;
  31. }
  32. if (regex.test(value)) {
  33. return;
  34. }
  35. const index = atRuleParamIndex(keyframesNode);
  36. const endIndex = index + value.length;
  37. report({
  38. index,
  39. endIndex,
  40. message: messages.expected(value, primary),
  41. node: keyframesNode,
  42. ruleName,
  43. result,
  44. });
  45. });
  46. };
  47. };
  48. rule.ruleName = ruleName;
  49. rule.messages = messages;
  50. rule.meta = meta;
  51. module.exports = rule;