persona-community-5/.pnpm-store/v3/files/da/d5eddd1e1147c335078d0dad42a323a220d9c4618f4058f9da3e969a15686f1c55cd9c1c5ac1ca85cae8205fe89a1c7c2505b61c529848868736c408709d91
rdev-worker a1d0d1bf1c
Some checks failed
ci/woodpecker/push/woodpecker Pipeline failed
build: /implement-feature community-ui --requirements 'Build the React commu...
2026-02-24 08:22:30 +00:00

61 lines
2.5 KiB
Plaintext

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const utils_1 = require("@typescript-eslint/utils");
const util_1 = require("../util");
exports.default = (0, util_1.createRule)({
name: 'no-dynamic-delete',
meta: {
docs: {
description: 'Disallow using the `delete` operator on computed key expressions',
recommended: 'strict',
},
fixable: 'code',
messages: {
dynamicDelete: 'Do not delete dynamically computed property keys.',
},
schema: [],
type: 'suggestion',
},
defaultOptions: [],
create(context) {
function createFixer(member) {
if (member.property.type === utils_1.AST_NODE_TYPES.Literal &&
typeof member.property.value === 'string') {
return createPropertyReplacement(member.property, `.${member.property.value}`);
}
return undefined;
}
return {
'UnaryExpression[operator=delete]'(node) {
if (node.argument.type !== utils_1.AST_NODE_TYPES.MemberExpression ||
!node.argument.computed ||
isAcceptableIndexExpression(node.argument.property)) {
return;
}
context.report({
fix: createFixer(node.argument),
messageId: 'dynamicDelete',
node: node.argument.property,
});
},
};
function createPropertyReplacement(property, replacement) {
return (fixer) => fixer.replaceTextRange(getTokenRange(property), replacement);
}
function getTokenRange(property) {
return [
(0, util_1.nullThrows)(context.sourceCode.getTokenBefore(property), util_1.NullThrowsReasons.MissingToken('token before', 'property')).range[0],
(0, util_1.nullThrows)(context.sourceCode.getTokenAfter(property), util_1.NullThrowsReasons.MissingToken('token after', 'property')).range[1],
];
}
},
});
function isAcceptableIndexExpression(property) {
return ((property.type === utils_1.AST_NODE_TYPES.Literal &&
['string', 'number'].includes(typeof property.value)) ||
(property.type === utils_1.AST_NODE_TYPES.UnaryExpression &&
property.operator === '-' &&
property.argument.type === utils_1.AST_NODE_TYPES.Literal &&
typeof property.argument.value === 'number'));
}
//# sourceMappingURL=no-dynamic-delete.js.map