-
-
Notifications
You must be signed in to change notification settings - Fork 622
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
React 19 & concurrent rendering #656
base: master
Are you sure you want to change the base?
Conversation
8f006b2
to
188ce94
Compare
I have a way forward with the tests. It involves wrapping rendering in |
@vadimdemedes @sindresorhus refactoring all of the tests is going to take substantial effort and I'm aware that there's no specific issue for this work. I just wanted to check in with you as to whether this change is something you're in favour of before I invest time into refactoring the tests. I think this is going to see pretty much every test touched, and so definitely requires some consensus and coordination. |
It would also be good to match the react-dom and react-three-fiber APIs of To summarise my proposal: const root = createRoot({ stdout, stdin });
root.render(<App />);` |
I think this is a good idea in general, but the final decision is up to @vadimdemedes. |
I think it also may be a bit too early. We cannot merge this until React 19 is out as otherwise we are not able to do new releases, and if this stays open for a long time with so many tests changes, it will be prone to lots of merge conflicts. |
That's a good point, I wonder if there is a different way forward. For example a new createRoot API could be shipped in a minor version (or I think there's lots of value around allowing users (particularly library authors) to opt into this change before React 19 is released. |
Let's go with the canary, it's just a word 😁 |
@tom-sherman can you release your fork under some name on npm for people like me to try? |
Wouldn't be possible to maintain both? Many projects do this by creating branches for major releases to be able to release patches while the current version lives in main/master. Even if it's not possible, there hasn't been much activity in recent months so maybe worth merging anyways? |
React 19 is out :-) |
It's a very ambitious title, I know...
The goal is to support latest canaries and concurrent rendering. If we ever get as far as this being working, it'll need to land in a new major version of ink and it'll be blocked by React 19 (unless we wanna publish an ink version that depends on a react canary version).
I think this also unlocks a more responsive Ink. Spun that out into a separate discussion here: #657