securityos/node_modules/stylelint/lib/rules/selector-attribute-operator.../index.js

111 lines
3.0 KiB
JavaScript

'use strict';
const ruleMessages = require('../../utils/ruleMessages');
const selectorAttributeOperatorSpaceChecker = require('../selectorAttributeOperatorSpaceChecker');
const validateOptions = require('../../utils/validateOptions');
const whitespaceChecker = require('../../utils/whitespaceChecker');
const ruleName = 'selector-attribute-operator-space-after';
const messages = ruleMessages(ruleName, {
expectedAfter: (operator) => `Expected single space after "${operator}"`,
rejectedAfter: (operator) => `Unexpected whitespace after "${operator}"`,
});
const meta = {
url: 'https://stylelint.io/user-guide/rules/selector-attribute-operator-space-after',
fixable: true,
deprecated: true,
};
/** @type {import('stylelint').Rule} */
const rule = (primary, _secondaryOptions, context) => {
return (root, result) => {
const checker = whitespaceChecker('space', primary, messages);
const validOptions = validateOptions(result, ruleName, {
actual: primary,
possible: ['always', 'never'],
});
if (!validOptions) {
return;
}
selectorAttributeOperatorSpaceChecker({
root,
result,
locationChecker: checker.after,
checkedRuleName: ruleName,
checkBeforeOperator: false,
fix: context.fix
? (attributeNode) => {
/** @type {{ operatorAfter: string, setOperatorAfter: (fixed: string) => void }} */
const { operatorAfter, setOperatorAfter } = (() => {
const rawOperator = attributeNode.raws.operator;
if (rawOperator) {
return {
operatorAfter: rawOperator.slice(
attributeNode.operator ? attributeNode.operator.length : 0,
),
setOperatorAfter(fixed) {
delete attributeNode.raws.operator;
if (!attributeNode.raws.spaces) attributeNode.raws.spaces = {};
if (!attributeNode.raws.spaces.operator)
attributeNode.raws.spaces.operator = {};
attributeNode.raws.spaces.operator.after = fixed;
},
};
}
const rawSpacesOperator =
attributeNode.raws.spaces && attributeNode.raws.spaces.operator;
const rawOperatorAfter = rawSpacesOperator && rawSpacesOperator.after;
if (rawOperatorAfter) {
return {
operatorAfter: rawOperatorAfter,
setOperatorAfter(fixed) {
rawSpacesOperator.after = fixed;
},
};
}
return {
operatorAfter:
(attributeNode.spaces.operator && attributeNode.spaces.operator.after) || '',
setOperatorAfter(fixed) {
if (!attributeNode.spaces.operator) attributeNode.spaces.operator = {};
attributeNode.spaces.operator.after = fixed;
},
};
})();
if (primary === 'always') {
setOperatorAfter(operatorAfter.replace(/^\s*/, ' '));
return true;
}
if (primary === 'never') {
setOperatorAfter(operatorAfter.replace(/^\s*/, ''));
return true;
}
return false;
}
: null,
});
};
};
rule.ruleName = ruleName;
rule.messages = messages;
rule.meta = meta;
module.exports = rule;