UNPKG

@stylistic/stylelint-plugin

Version:
101 lines (82 loc) 2.5 kB
import stylelint from "stylelint" import { addNamespace } from "../../utils/addNamespace.js" import blockString from "../../utils/blockString.js" import { getRuleDocUrl } from "../../utils/getRuleDocUrl.js" import hasBlock from "../../utils/hasBlock.js" import rawNodeString from "../../utils/rawNodeString.js" import whitespaceChecker from "../../utils/whitespaceChecker.js" let { utils: { report, ruleMessages, validateOptions } } = stylelint let shortName = `block-closing-brace-space-after` export let ruleName = addNamespace(shortName) export let messages = ruleMessages(ruleName, { expectedAfter: () => `Expected single space after "}"`, rejectedAfter: () => `Unexpected whitespace after "}"`, expectedAfterSingleLine: () => `Expected single space after "}" of a single-line block`, rejectedAfterSingleLine: () => `Unexpected whitespace after "}" of a single-line block`, expectedAfterMultiLine: () => `Expected single space after "}" of a multi-line block`, rejectedAfterMultiLine: () => `Unexpected whitespace after "}" of a multi-line block`, }) export let meta = { url: getRuleDocUrl(shortName), } /** @type {import('stylelint').Rule} */ function rule (primary) { let checker = whitespaceChecker(`space`, primary, messages) return (root, result) => { let validOptions = validateOptions(result, ruleName, { actual: primary, possible: [ `always`, `never`, `always-single-line`, `never-single-line`, `always-multi-line`, `never-multi-line`, ], }) if (!validOptions) { return } // Check both kinds of statements: rules and at-rules root.walkRules(check) root.walkAtRules(check) /** * @param {import('postcss').Rule | import('postcss').AtRule} statement */ function check (statement) { let nextNode = statement.next() if (!nextNode) { return } if (!hasBlock(statement)) { return } let reportIndex = statement.toString().length let source = rawNodeString(nextNode) // Skip a semicolon at the beginning, if any if (source && source.startsWith(`;`)) { source = source.slice(1) reportIndex++ } checker.after({ source, index: -1, lineCheckStr: blockString(statement), err: (msg) => { report({ message: msg, node: statement, index: reportIndex, endIndex: reportIndex, result, ruleName, }) }, }) } } } rule.ruleName = ruleName rule.messages = messages rule.meta = meta export default rule