|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960 |
- // @ts-nocheck
-
- 'use strict';
-
- const valueParser = require('postcss-value-parser');
-
- const declarationValueIndex = require('../../utils/declarationValueIndex');
- const getDeclarationValue = require('../../utils/getDeclarationValue');
- const report = require('../../utils/report');
- const ruleMessages = require('../../utils/ruleMessages');
- const validateOptions = require('../../utils/validateOptions');
-
- const ruleName = 'color-no-hex';
-
- const messages = ruleMessages(ruleName, {
- rejected: (hex) => `Unexpected hex color "${hex}"`,
- });
-
- const HEX = /^#[0-9A-Za-z]+/;
- const IGNORED_FUNCTIONS = new Set(['url']);
-
- function rule(actual) {
- return (root, result) => {
- const validOptions = validateOptions(result, ruleName, { actual });
-
- if (!validOptions) {
- return;
- }
-
- root.walkDecls((decl) => {
- const parsedValue = valueParser(getDeclarationValue(decl));
-
- parsedValue.walk((node) => {
- if (isIgnoredFunction(node)) return false;
-
- if (!isHexColor(node)) return;
-
- report({
- message: messages.rejected(node.value),
- node: decl,
- index: declarationValueIndex(decl) + node.sourceIndex,
- result,
- ruleName,
- });
- });
- });
- };
- }
-
- function isIgnoredFunction({ type, value }) {
- return type === 'function' && IGNORED_FUNCTIONS.has(value.toLowerCase());
- }
-
- function isHexColor({ type, value }) {
- return type === 'word' && HEX.test(value);
- }
-
- rule.ruleName = ruleName;
- rule.messages = messages;
- module.exports = rule;
|