securityos/node_modules/eslint-plugin-react/lib/rules/react-in-jsx-scope.js

57 lines
1.3 KiB
JavaScript
Raw Permalink Normal View History

2024-09-06 15:32:35 +00:00
/**
* @fileoverview Prevent missing React when using JSX
* @author Glen Mailer
*/
'use strict';
const variableUtil = require('../util/variable');
const pragmaUtil = require('../util/pragma');
const docsUrl = require('../util/docsUrl');
const report = require('../util/report');
// -----------------------------------------------------------------------------
// Rule Definition
// -----------------------------------------------------------------------------
const messages = {
notInScope: '\'{{name}}\' must be in scope when using JSX',
};
module.exports = {
meta: {
docs: {
description: 'Disallow missing React when using JSX',
category: 'Possible Errors',
recommended: true,
url: docsUrl('react-in-jsx-scope'),
},
messages,
schema: [],
},
create(context) {
const pragma = pragmaUtil.getFromContext(context);
function checkIfReactIsInScope(node) {
const variables = variableUtil.variablesInScope(context);
if (variableUtil.findVariable(variables, pragma)) {
return;
}
report(context, messages.notInScope, 'notInScope', {
node,
data: {
name: pragma,
},
});
}
return {
JSXOpeningElement: checkIfReactIsInScope,
JSXOpeningFragment: checkIfReactIsInScope,
};
},
};