stylelint-scss
Version:
A collection of SCSS-specific rules for Stylelint
59 lines (44 loc) • 1.48 kB
JavaScript
;
const { utils } = require("stylelint");
const namespace = require("../../utils/namespace");
const ruleUrl = require("../../utils/ruleUrl");
const valueParser = require("postcss-value-parser");
const ruleName = namespace("function-calculation-no-interpolation");
const messages = utils.ruleMessages(ruleName, {
rejected: func => `Unexpected interpolation in "${func}".`
});
const meta = {
url: ruleUrl(ruleName)
};
function rule(actual) {
return (root, result) => {
const validOptions = utils.validateOptions(result, ruleName, { actual });
if (!validOptions) {
return;
}
const calculationFunctions = ["calc", "max", "min", "clamp"];
root.walkDecls(decl => {
valueParser(decl.value).walk(node => {
if (node.type !== "function" || node.value === "") return;
if (!calculationFunctions.includes(node.value)) return;
// Interpolation is valid in SassScript.
if (decl.type === "decl" && decl.prop.startsWith("--")) return;
const interpolation = node.nodes.find(
({ type, value }) => type === "word" && /^#{.*|\s*}/.test(value)
);
if (!interpolation) return;
utils.report({
message: messages.rejected(node.value),
node: decl,
word: interpolation.value,
result,
ruleName
});
});
});
};
}
rule.ruleName = ruleName;
rule.messages = messages;
rule.meta = meta;
module.exports = rule;