UNPKG

@stylistic/stylelint-plugin

Version:
69 lines (52 loc) 1.46 kB
import stylelint from "stylelint" import { addNamespace } from "../../utils/addNamespace/index.js" import { getRuleDocUrl } from "../../utils/getRuleDocUrl/index.js" import { isStandardSyntaxAtRule } from "../../utils/isStandardSyntaxAtRule/index.js" let { utils: { report, ruleMessages, validateOptions } } = stylelint let shortName = `at-rule-name-case` export let ruleName = addNamespace(shortName) export let messages = ruleMessages(ruleName, { expected: (actual, expected) => `Expected "${actual}" to be "${expected}"`, }) export let meta = { url: getRuleDocUrl(shortName), fixable: true, } /** @type {import('stylelint').Rule} */ function rule (primary) { return (root, result) => { let validOptions = validateOptions(result, ruleName, { actual: primary, possible: [`lower`, `upper`], }) if (!validOptions) { return } /** @type {'lower' | 'upper'} */ let expectation = primary root.walkAtRules((atRule) => { if (!isStandardSyntaxAtRule(atRule)) { return } let name = atRule.name let expectedName = expectation === `lower` ? name.toLowerCase() : name.toUpperCase() if (name === expectedName) { return } report({ message: messages.expected, messageArgs: [name, expectedName], node: atRule, ruleName, result, fix () { atRule.name = expectedName }, }) }) } } rule.ruleName = ruleName rule.messages = messages rule.meta = meta export default rule