first commit
This commit is contained in:
213
node_modules/stylelint/lib/rules/length-zero-no-unit/index.cjs
generated
vendored
Normal file
213
node_modules/stylelint/lib/rules/length-zero-no-unit/index.cjs
generated
vendored
Normal file
@@ -0,0 +1,213 @@
|
||||
// NOTICE: This file is generated by Rollup. To modify it,
|
||||
// please instead edit the ESM counterpart and rebuild with Rollup (npm run build).
|
||||
'use strict';
|
||||
|
||||
const valueParser = require('postcss-value-parser');
|
||||
const nodeFieldIndices = require('../../utils/nodeFieldIndices.cjs');
|
||||
const typeGuards = require('../../utils/typeGuards.cjs');
|
||||
const validateTypes = require('../../utils/validateTypes.cjs');
|
||||
const getAtRuleParams = require('../../utils/getAtRuleParams.cjs');
|
||||
const getDeclarationValue = require('../../utils/getDeclarationValue.cjs');
|
||||
const isCustomProperty = require('../../utils/isCustomProperty.cjs');
|
||||
const isMathFunction = require('../../utils/isMathFunction.cjs');
|
||||
const isStandardSyntaxAtRule = require('../../utils/isStandardSyntaxAtRule.cjs');
|
||||
const isStandardSyntaxDeclaration = require('../../utils/isStandardSyntaxDeclaration.cjs');
|
||||
const units = require('../../reference/units.cjs');
|
||||
const optionsMatches = require('../../utils/optionsMatches.cjs');
|
||||
const report = require('../../utils/report.cjs');
|
||||
const ruleMessages = require('../../utils/ruleMessages.cjs');
|
||||
const setAtRuleParams = require('../../utils/setAtRuleParams.cjs');
|
||||
const setDeclarationValue = require('../../utils/setDeclarationValue.cjs');
|
||||
const validateOptions = require('../../utils/validateOptions.cjs');
|
||||
|
||||
const ruleName = 'length-zero-no-unit';
|
||||
|
||||
const messages = ruleMessages(ruleName, {
|
||||
rejected: 'Unexpected unit',
|
||||
});
|
||||
|
||||
const meta = {
|
||||
url: 'https://stylelint.io/user-guide/rules/length-zero-no-unit',
|
||||
fixable: true,
|
||||
};
|
||||
|
||||
/** @import { AtRule, Declaration } from 'postcss' */
|
||||
/** @import { ParsedValue, Node } from 'postcss-value-parser' */
|
||||
|
||||
/** @type {import('stylelint').CoreRules[ruleName]} */
|
||||
const rule = (primary, secondaryOptions) => {
|
||||
return (root, result) => {
|
||||
const validOptions = validateOptions(
|
||||
result,
|
||||
ruleName,
|
||||
{
|
||||
actual: primary,
|
||||
},
|
||||
{
|
||||
actual: secondaryOptions,
|
||||
possible: {
|
||||
ignore: ['custom-properties'],
|
||||
ignoreFunctions: [validateTypes.isString, validateTypes.isRegExp],
|
||||
},
|
||||
optional: true,
|
||||
},
|
||||
);
|
||||
|
||||
if (!validOptions) return;
|
||||
|
||||
/**
|
||||
* @param {AtRule | Declaration} node
|
||||
* @param {number} nodeIndex
|
||||
* @param {Node} valueNode
|
||||
* @param {ParsedValue} parsedValue
|
||||
*/
|
||||
function check(node, nodeIndex, valueNode, parsedValue) {
|
||||
const { value, sourceIndex } = valueNode;
|
||||
|
||||
if (isMathFunction(valueNode)) return false;
|
||||
|
||||
if (typeGuards.isValueFunction(valueNode) && optionsMatches(secondaryOptions, 'ignoreFunctions', value))
|
||||
return false;
|
||||
|
||||
if (!typeGuards.isValueWord(valueNode)) return;
|
||||
|
||||
const dimension = valueParser.unit(value);
|
||||
const decompositionFailed = dimension === false;
|
||||
|
||||
if (decompositionFailed) return;
|
||||
|
||||
const { number, unit } = dimension;
|
||||
|
||||
if (!isZero(number)) return;
|
||||
|
||||
if (isNumber(unit)) return;
|
||||
|
||||
if (!isLength(unit)) return;
|
||||
|
||||
if (isFraction(unit)) return;
|
||||
|
||||
const fix = () => {
|
||||
valueNode.value = number.startsWith('.') ? number.slice(1) : number;
|
||||
|
||||
switch (node.type) {
|
||||
case 'atrule':
|
||||
setAtRuleParams(node, parsedValue.toString());
|
||||
break;
|
||||
case 'decl':
|
||||
setDeclarationValue(node, parsedValue.toString());
|
||||
break;
|
||||
}
|
||||
};
|
||||
|
||||
const index = nodeIndex + sourceIndex + number.length;
|
||||
const endIndex = index + unit.length;
|
||||
|
||||
report({
|
||||
index,
|
||||
endIndex,
|
||||
message: messages.rejected,
|
||||
node,
|
||||
result,
|
||||
ruleName,
|
||||
fix,
|
||||
});
|
||||
}
|
||||
|
||||
/** @param {AtRule} node */
|
||||
function checkAtRule(node) {
|
||||
if (!isStandardSyntaxAtRule(node)) return;
|
||||
|
||||
const index = nodeFieldIndices.atRuleParamIndex(node);
|
||||
const parsedValue = valueParser(getAtRuleParams(node));
|
||||
|
||||
parsedValue.walk((valueNode) => check(node, index, valueNode, parsedValue));
|
||||
}
|
||||
|
||||
/** @param {Declaration} node */
|
||||
function checkDecl(node) {
|
||||
const { prop } = node;
|
||||
|
||||
if (!isStandardSyntaxDeclaration(node)) return;
|
||||
|
||||
if (isLineHeight(prop)) return;
|
||||
|
||||
if (isFlex(prop)) return;
|
||||
|
||||
if (optionsMatches(secondaryOptions, 'ignore', 'custom-properties') && isCustomProperty(prop))
|
||||
return;
|
||||
|
||||
const index = nodeFieldIndices.declarationValueIndex(node);
|
||||
const parsedValue = valueParser(getDeclarationValue(node));
|
||||
|
||||
parsedValue.walk((valueNode, valueNodeIndex, valueNodes) => {
|
||||
if (isLineHeightValue(node, valueNodes, valueNodeIndex)) return;
|
||||
|
||||
return check(node, index, valueNode, parsedValue);
|
||||
});
|
||||
}
|
||||
|
||||
root.walkAtRules(checkAtRule);
|
||||
root.walkDecls(checkDecl);
|
||||
};
|
||||
};
|
||||
|
||||
/**
|
||||
* @param {Declaration} decl
|
||||
* @param {Node[]} nodes
|
||||
* @param {number} index
|
||||
*/
|
||||
function isLineHeightValue({ prop }, nodes, index) {
|
||||
const lastNode = nodes[index - 1];
|
||||
|
||||
return (
|
||||
prop.toLowerCase() === 'font' && lastNode && lastNode.type === 'div' && lastNode.value === '/'
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} prop
|
||||
*/
|
||||
function isLineHeight(prop) {
|
||||
return prop.toLowerCase() === 'line-height';
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} prop
|
||||
*/
|
||||
function isFlex(prop) {
|
||||
return prop.toLowerCase() === 'flex';
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} unit
|
||||
*/
|
||||
function isLength(unit) {
|
||||
return units.lengthUnits.has(unit.toLowerCase());
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} unit
|
||||
*/
|
||||
function isFraction(unit) {
|
||||
return unit.toLowerCase() === 'fr';
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} number
|
||||
*/
|
||||
function isZero(number) {
|
||||
return Number.parseFloat(number) === 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param {string} unit
|
||||
*/
|
||||
function isNumber(unit) {
|
||||
return unit === '';
|
||||
}
|
||||
|
||||
rule.ruleName = ruleName;
|
||||
rule.messages = messages;
|
||||
rule.meta = meta;
|
||||
|
||||
module.exports = rule;
|
||||
Reference in New Issue
Block a user