UNPKG

stylelint

Version:
61 lines (50 loc) 1.53 kB
import valueParser from "postcss-value-parser" import { isStandardSyntaxValue, isVariable, report, ruleMessages, validateOptions, } from "../../utils" export const ruleName = "function-url-data-uris" export const messages = ruleMessages(ruleName, { expected: "Expected a data URI", rejected: "Unexpected data URI", }) export default function (expectation) { return (root, result) => { const validOptions = validateOptions(result, ruleName, { actual: expectation, possible: [ "always", "never", ], }) if (!validOptions) { return } root.walkDecls(function (decl) { valueParser(decl.value).walk(valueNode => { if (valueNode.type !== "function" || valueNode.value.toLowerCase() !== "url" || !valueNode.nodes.length > 0 ) { return } const urlValueNode = valueNode.nodes[0] if (!urlValueNode.value || !isStandardSyntaxValue(urlValueNode.value) || isVariable(urlValueNode.value) ) { return } const valueContainDataUris = urlValueNode.value.toLowerCase().indexOf("data:") === 0 const needUrlDataUris = expectation === "always" if (valueContainDataUris && needUrlDataUris || !valueContainDataUris && !needUrlDataUris ) { return } const message = needUrlDataUris ? messages.expected : messages.rejected report({ message, node: decl, result, ruleName, }) }) }) } }