no-find-dom-node.js 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /**
  2. * @fileoverview Prevent usage of findDOMNode
  3. * @author Yannick Croissant
  4. */
  5. 'use strict';
  6. const docsUrl = require('../util/docsUrl');
  7. const report = require('../util/report');
  8. // ------------------------------------------------------------------------------
  9. // Rule Definition
  10. // ------------------------------------------------------------------------------
  11. const messages = {
  12. noFindDOMNode: 'Do not use findDOMNode. It doesn’t work with function components and is deprecated in StrictMode. See https://reactjs.org/docs/react-dom.html#finddomnode',
  13. };
  14. module.exports = {
  15. meta: {
  16. docs: {
  17. description: 'Disallow usage of findDOMNode',
  18. category: 'Best Practices',
  19. recommended: true,
  20. url: docsUrl('no-find-dom-node'),
  21. },
  22. messages,
  23. schema: [],
  24. },
  25. create(context) {
  26. return {
  27. CallExpression(node) {
  28. const callee = node.callee;
  29. const isfindDOMNode = (callee.name === 'findDOMNode')
  30. || (callee.property && callee.property.name === 'findDOMNode');
  31. if (!isfindDOMNode) {
  32. return;
  33. }
  34. report(context, messages.noFindDOMNode, 'noFindDOMNode', {
  35. node: callee,
  36. });
  37. },
  38. };
  39. },
  40. };