webhook-action/node_modules/eslint-plugin-github/lib/rules/no-innerText.js

35 lines
971 B
JavaScript
Raw Normal View History

module.exports = {
meta: {
2022-11-10 10:43:16 +00:00
type: 'problem',
docs: {
description: 'disallow `Element.prototype.innerText` in favor of `Element.prototype.textContent`',
2024-03-28 02:00:41 +00:00
url: require('../url')(module),
2022-11-10 10:43:16 +00:00
},
fixable: 'code',
2024-03-28 02:00:41 +00:00
schema: [],
},
create(context) {
return {
MemberExpression(node) {
2024-03-28 02:00:41 +00:00
// If the member expression is part of a call expression like `.innerText()` then it is not the same
// as the `Element.innerText` property, and should not trigger a warning
if (node.parent.type === 'CallExpression') return
if (node.property && node.property.name === 'innerText') {
context.report({
meta: {
2024-03-28 02:00:41 +00:00
fixable: 'code',
},
node: node.property,
message: 'Prefer textContent to innerText',
fix(fixer) {
return fixer.replaceText(node.property, 'textContent')
2024-03-28 02:00:41 +00:00
},
})
}
2024-03-28 02:00:41 +00:00
},
}
2024-03-28 02:00:41 +00:00
},
}