Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Slot] Access ref from props else fallback to element.ref #2811

Closed
wants to merge 2 commits into from

Conversation

chungweileong94
Copy link
Contributor

Description

fix #2769

Starting from the React 18.3.0 canary, accessing the ref via element.ref will throw a warning, and element.ref will be removed in the future React release.

Instead, we should access the ref from props. To maintain the backward compatibility, we can do children.props.ref ?? children.ref.

@ZipBrandon
Copy link

Just chiming in to say that I had an issue with Portal when used in conjunction with framer-motion in the React canary releases since 19.0.0-canary-7a2609eed-20240403 and that this was the fix. Thank you.

@alaney2
Copy link

alaney2 commented Apr 10, 2024

Thanks for fixing this

@borispoehland
Copy link

Thank you!

@tillka
Copy link

tillka commented Apr 26, 2024

Is there a way to fix this manually / locally until the official fix is out? The 7x 'element.ref' warnings I am getting on each page refresh are very annoying.

@juliusmarminge
Copy link

I also had to patch @radix-ui/react-presence to get rid of all warnings:

CleanShot 2024-04-26 at 21 31 55@2x

@chungweileong94
Copy link
Contributor Author

chungweileong94 commented Apr 26, 2024

I also had to patch @radix-ui/react-presence to get rid of all warnings:

CleanShot 2024-04-26 at 21 31 55@2x

Ah thx, wasn’t able to find the others, will include this as well.

@chungweileong94
Copy link
Contributor Author

@juliusmarminge I applied the same fix to @radix-ui/react-presence too.

Copy link

@juliusmarminge juliusmarminge left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@tungv
Copy link

tungv commented May 6, 2024

Just a gentle reminder that this PR being merged and released is so valuable for a lot of people. Thank you.

const ref = useComposedRefs(presence.ref, (child as any).ref);
// Accessing the ref from props, else fallback to element.ref
// https://github.com/facebook/react/pull/28348
const childrenRef = child.props.ref ?? (child as any).ref;
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It's fine to access child.ref conditionally. React only warns when accessing child.ref iff a ref prop is actually passed.

Copy link

@nicksrandall nicksrandall left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@Brenndoerfer
Copy link

Would be great to get an approval from one of the code owners on this.. it also impacts Shadcn/ui

@alphaBiota
Copy link

hey @andy-hook @benoitgrelard

hoping this gets approved soon. thanks!

@sannajammeh
Copy link

sannajammeh commented May 28, 2024

As this is taking a little while, here's how to suppress the annoying logs until its merged:

_supressLogs.ts

// TODO - delete when https://github.com/radix-ui/primitives/pull/2811 gets merged 
const prevConsoleError = console.error;
const prevConsoleWarn = console.warn;

console.error = (...args) => {
  if (args[0].includes("Warning: Accessing element.ref")) {
    return;
  }

  prevConsoleError(...args);
};

console.warn = (...args) => {
  if (args[0].includes("Warning: Accessing element.ref")) {
    return;
  }

  prevConsoleWarn(...args);
};

Import this globally at your app root.
For Next.js this would be

Root layout.tsx

import "./_supressLogs";
// Your root layout

And Root client provider file _Providers.tsx

"use client";

import "./_supressLogs";
// Your provider

@bcanfield
Copy link

lgtm

@topaxi
Copy link

topaxi commented Jun 3, 2024

Please stop unnecessarily approving this PR. It adds noise to anyone who is subscribed. As a maintainer of OSS stuff myself, I can guarantee you, that adding noise will not help push things forward. Maintainers will get to it when they have time, they are most certainly well aware that this is a desired issue/PR.

@vladmoroz vladmoroz mentioned this pull request Jun 4, 2024
@vladmoroz
Copy link
Contributor

Thanks for the contribution @chungweileong94. This will be integrated altogether with the other changes required to support React 19 in #2934

@vladmoroz vladmoroz closed this Jun 4, 2024
@mooxl
Copy link

mooxl commented Jun 20, 2024

the new version is out and resolves the ref issue 🪩

nikolailehbrink added a commit to nikolailehbrink/portfolio that referenced this pull request Jul 8, 2024
- This prevents a warning coming up for handling refs: radix-ui/primitives#2811
@louishugens
Copy link

Hello guys. I still get this error: Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release. Is 1.1.0 the last version? I have a nextjs 15 project

@chungweileong94
Copy link
Contributor Author

chungweileong94 commented Nov 20, 2024

Hello guys. I still get this error: Accessing element.ref was removed in React 19. ref is now a regular prop. It will be removed from the JSX Element type in a future release. Is 1.1.0 the last version? I have a nextjs 15 project

That should be the latest version that contains the fix. If you are using component from shadcn ui, you will need to manually remove all the forwardRef usages. Best if you can provide a small repro if that doesn't solve your issue.

@louishugens
Copy link

Thanks @chungweileong94. I am indeed using shadcn-ui. It is complaining about this file node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/packages/react/slot/src/Slot.tsx (66:71) but i can't locate it

@chungweileong94
Copy link
Contributor Author

Thanks @chungweileong94. I am indeed using shadcn-ui. It is complaining about this file node_modules/@radix-ui/react-menu/node_modules/@radix-ui/react-slot/dist/packages/react/slot/src/Slot.tsx (66:71) but i can't locate it

I looks like a dependency problem to me, have you try to update all the radix packages to the latest version?

@louishugens
Copy link

i did try to update. No success. Also i get this from time to time: Cannot update a component (HotReload) while rendering a different component (SlotClone). To locate the bad setState() call inside SlotClone, follow the stack trace as described in https://react.dev/link/setstate-in-render

@lpbonomi
Copy link

@louishugens @chungweileong94 I think that the problem is the react-slot package still has forwardedRef in it:

https://github.com/radix-ui/primitives/blob/main/packages/react/slot/src/Slot.tsx

@chungweileong94
Copy link
Contributor Author

@louishugens @chungweileong94 I think that the problem is the react-slot package still has forwardedRef in it:

https://github.com/radix-ui/primitives/blob/main/packages/react/slot/src/Slot.tsx

It's been awhile since I last created this PR, but as far as I can remember, the warning that React was throwing isn't about React.forwardRef, but instead it was about accessing the ref via element.ref. But it could be something new that I wasn't aware of.

@f5io
Copy link

f5io commented Nov 25, 2024

@louishugens @chungweileong94 I think that the problem is the react-slot package still has forwardedRef in it:

https://github.com/radix-ui/primitives/blob/main/packages/react/slot/src/Slot.tsx

in an attempt to update to react 18.3, i am seeing exactly this issue. i was under the impression that @radix-ui is ready for react 19, apologies if i'm being dumb, but what am i missing here?

edit: this is the error i am seeing:

Warning: Function components cannot be given refs. Attempts to access this ref will fail. Did you mean to use React.forwardRef()?

Check the render method of `SlotClone`.

@chungweileong94
Copy link
Contributor Author

in an attempt to update to react 18.3, i am seeing exactly this issue. i was under the impression that @radix-ui is ready for react 19, apologies if i'm being dumb, but what am i missing here?

I don't think React 18.3 will suffer the same problem though. But mind if you can provide a small repro for the error that you are facing?

@f5io
Copy link

f5io commented Nov 25, 2024

in an attempt to update to react 18.3, i am seeing exactly this issue. i was under the impression that @radix-ui is ready for react 19, apologies if i'm being dumb, but what am i missing here?

I don't think React 18.3 will suffer the same problem though. But mind if you can provide a small repro for the error that you are facing?

it appears after explicitly updating to react@rc this error disappears, as far as i can tell. if i find some time i will attempt a small repro against 18.3.

@Hexi1997
Copy link

@louishugens @chungweileong94 I think that the problem is the react-slot package still has forwardedRef in it:

main/packages/react/slot/src/Slot.tsx

The problem still exists.

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.

[Slot] React 18.3.0 canary, ref is now a regular prop