Skip to content

Conversation

@eps1lon
Copy link
Member

@eps1lon eps1lon commented Sep 25, 2022

For https://github.com/reactjs/rfcs/blob/createlement-rfc/text/0000-create-element-changes.md#deprecate-string-refs-and-remove-production-mode-_owner-field

In: <div ref="refComponent" />;
Out:

<div
  ref={(current) => {
    this.refs['refComponent'] = current;
  }}
/>

Note that this codemod only works for React 18.3 or higher.

Should not be used if the codebase contains warnings about string refs without owners e.g.

Component "ComponentNameWithRef" contains the string ref "someStringRefName". 
Support for string refs will be removed in a future major release.
This case cannot be automatically converted to an arrow function.
We ask you to manually fix this case by using useRef() or createRef() instead.
Learn more about using refs safely here:
https://reactjs.org/link/strict-mode-string-ref

Test plan

  • yarn test
  • node bin/react-codemod.js string-refs ~/repos/react

@eps1lon
Copy link
Member Author

eps1lon commented Jan 2, 2023

We decided against a codemdoddable warning

@eps1lon eps1lon closed this Jan 2, 2023
@eps1lon eps1lon deleted the feat/string-refs branch January 2, 2023 17:16
@eps1lon eps1lon restored the feat/string-refs branch April 17, 2024 20:38
@eps1lon eps1lon reopened this Apr 17, 2024
@eps1lon
Copy link
Member Author

eps1lon commented Apr 17, 2024

The plan is to land unfreezing this.refs for 18.3 and 19. Then we can use this codemod.

@eps1lon eps1lon marked this pull request as ready for review April 25, 2024 00:06
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants