π¨ #186: React Conf, Compiler, Universal RSC, React-Router, Google Maps, Million Lint, Pigment, Restyle, Storybook, SSRF, Inline Styles, New Arch, Expo, Bootsplash, Skia, RN-Video...
Hi everyone!
This has been a busy week for us π. That React conf didn't disappoint! We weren't there, but our flyer was π. We not only had great conf announcements (notably the compiler!), but we had great community articles that I had to postpone a few of them to next week.
Although it's unlikely to calm down because 2 major confs start tomorrow:
- Vercel Ship, during which Next.js 15 should be announced with a less aggressive caching strategy, Turborepo in dev, Compiler support and more.
- App.js Conf, also with great React Native announcements expected.
Have a good read and see you next week!
π‘ Check this newsletter on Twitter - visual format π¨
To support me:
- π Recommend the newsletter to your friends: it really helps!
- πΈ Sponsor the newsletter
- 𧡠Retweet the latest Twitter thread
Don't miss the next email!
πΈ Sponsorβ
React-admin: The Open-Source Framework for B2B apps
Speed up the development of your single-page applications with the acclaimed frontend frameworkπ. Built with TanStack Query, react-hook-form, react-router & material UI, React-admin lets you create rich user experiences on top of REST or GraphQL APIs.
Beyond CRUD pages, React-admin has many advanced functionalities to meet your needs. Its complete toolkit offers a calendar π , customizable Kanban board, content versioning π, nested forms & more. Add real-time updates π₯, tree π² structures and detailed audit logs via headless hooks and themeable components.
Ready to take your development to the next level? Make React-admin your go-to framework & join over half a million daily users. Try it now!
βοΈ Reactβ
The React team published a recap blog post of React Conf, just in time for todayβs newsletter π€. It presents all the talks and the main announcements. I haven't seen all of them yet, but my highlights so far are:
- React 19 is in RC, and a stable release is expected in the next few weeks
- The React Compiler is out and looks really powerful
- Universal React Server Components are coming to Expo and the demo is really impressive
- Remix and React Router are merging. Remix v3 will finally be React Router v7.
- The Real-time React Server Components demo makes RSCs stateful and opens new possibilities that remind me of Phoenix LiveView
- React now coordinates HTML tags, which is hugely underrated
Again these are just my personal favorites. We already covered most React 19 features in the newsletter, and the React 19 beta blog post remains the reference for discovering all the new features coming in the next major version.
The compiler probably deserves its own section right. TLDR: the compiler optimizes your existing code automatically and gives you fine-grained reactivity using regular JS values. Try the React Compiler Playground to see how it works, and understand how it optimizes your code.
It has been successfully rolled out on Instagram web with great results (2.5x faster interactions). It statically analyses your code, one file at a time, and memoizes what can safely be optimized, with even greater granularity than you could do by hand. If you follow the Rules of React, you shouldnβt need to rewrite any code. The ESLint plugin tells you about problematic code that the compiler detects. It does not play well with proxy-based solutions like MobX. Configuration options and opt-in/out directives enable you to try the compiler gradually on your codebase.
The compiler is initially written in TypeScript and ships with Babel bindings, but donβt be disappointed because its logic is decoupled. Support for SWC should come next, and weβll probably have a port in Rust a bit later (they already made a POC for that to ensure itβs feasible).
It is worth mentioning that the React team always had in mind to have a compiler for React (see Andrew Clarkβs thread). And this is only the beginning, they now have the infrastructure to build even more powerful things. Iβm pretty sure sooner or later we wonβt need anymore a dependency array, and that the compiler will be able to optimize fine-grained context consumption (relevant tweet).
π Related resources worth checking:
- π React Compiler With React 18: The compiler is not a React 19 feature. Jack shows a POC of using it under React 18 by providing a very simple compiler runtime hook. Lauren from the React Compiler team just confirmed itβs ok to do so and provided an official polyfill that you can use temporarily, although itβs recommended to upgrade to React 19.
- π₯ Jack Herrington - React Compiler: In-Depth Beyond React Conf 2024
- π₯ Theo - React Just Changed Forever
- 𧡠Theo - Clearing up some React Compiler misunderstandings
Merging Remix and React Router
This is another big announcement from React Conf. Remix and React Router have converged so much (thanks to the Vite plugin and SPA mode) that it doesnβt really make sense anymore to keep both. Technically, instead of shipping Remix v3, they plan to add an optional Vite plugin to React Router v7, which will remain retro-compatible, and also bring new features (RSC, server-actions, static pre-renderingβ¦). See also the follow-up post Incremental Path to React 19: React Conf Follow-Up.
- πΈ Conversational AI and context-aware LLM chat with React
- π React 19 lets you write impossible components: A great article from Mux that adopted RSCs early, explaining that we only scratched the surface of the new patterns RSCs enable. The changelog pagination example is cool and shows that even libraries like React Query might become less useful.
- π Introducing Pigment CSS: the next generation of CSS-in-JS: the MUI team explains the motivations to create their own in-house CSS-in-JS solution, built on top of the WyW-in-JS toolkit, that should power MUI v6 later this year. It is compatible with RSCs. The adoption for MUI/Emotion/StyledComponent users should be easy.
- π Digging for SSRF in NextJS apps: Security researchers explain blind Server Side Request Forgery vulnerabilities they found in Next.js related to the Image component and Server Actions implementations. Those vulnerabilities have been patched since Next.js 14.1.1 already (January 2024).
- π Prefer Multiple Compositions: If your component has a finite set of cases to handle, it will be more maintainable to have clear separate if/else branches for each cases rather than spreading conditionals everywhere in JSX.
- π Prefer Noun-Adjective Naming: I also prefer to name a component βButtonPrimaryβ instead of βPrimaryButtonβ. Related things remain grouped alphabetically, and are easier to lookup in the IDE.
- π Inline Styles on Steroids: With projects such as CSS Hooks, and the web platform planning to add support for inline style nesting, itβs only a matter of time until inline styles make a huge comeback. The author of Fela recreates the DX of a good CSS-in-JS library on top of CSS Hooks thanks to 2 new projects heβs working on.
- π Quantifying the Impact of Styled Components on Server Response Times: Uses SpeedScope (more powerful than Chrome DevTools) to analyze a CPU trace and concludes that style injection takes 47% of SSR time.
- π Storybook - Portable stories for Playwright Component Tests: Although Storybook provides a play() function using a Playwright test runner, you might still want to use Playwright Component testing directly, and reuse your existing stories there.
- π Deploying Remix to Cloudflare with SST: Using SST to deploy your app to a major cloud can be a nice alternative to DX platforms like Vercel/Netlify. TIL that itβs so simple to use, and it also supports deploying to Cloudflare.
- π¦ Restyle: New CSS-in-JS library compatible with RSC thatβs leveraging the brand-new style hoisting and deduplication feature of React 19. Those new React primitives were also designed with CSS-in-JS libs in mind, and itβs great to see the community already leveraging them. Itβs also interesting for distributing CSS as part of a React library npm package.
- π¦ React Google Maps 1.0: The official Google Maps library for React is now stable, maintained by the OpenJS Foundation.
- π¦ Million Lint 1.0-rc: IDE extension that automatically finds and fixes performance issues for you. Unlike the React compiler, it is based on runtime analysis and can detect additional performance problems that the compiler canβt. Both can be used in tandem.
- π¦ Zustand 5.0-beta - Upgrade guide available - drop deprecated features, upgrades React/TS
- π¦ Storybook 8.1 - tag filtering, typesafe mocking, beforeEach, portable stories API
- π¦ Storybook-Rsbuild - Storybook builder powered by Rsbuild
Don't miss the next email!
πΈ Sponsorβ
Next.js auth tutorial with RSCs and Server Actions
The latest tutorial with WorkOS and Sam Selikoff shows how you can easily add AuthKit's hosted login box to a Next.js app:
π Get started using the Authkit <> Next.js integration library
π€ Set up environment variables, configure the callback route and middleware, and implement signIn and signOut functionalities
βοΈ Protect routes in the Next.js app from unauthenticated users with the getUser function
AuthKit can be used with WorkOS User Management, which supports MFA, identity linking, email verification, user impersonation, and more.
Best of all, it's free up to 1,000,000 MAUs π
π± React-Nativeβ
This section is authored by Benedikt.
React Conf is officially behind us, and I hope you had a chance to look at the recordings of the awesome presentations on YouTube. My biggest meta-takeaway was just how much RN content there was in the conference! As RN is very much developed out in the open and in collaboration with the whole community, there were no surprising βbig announcements,β but it was a very good summary of the current state of RN and an outlook on the road ahead. The most impressive and inspiring part for me was Evan Baconβs vision for Universal React Server Components, which he presented using an absolute killer demo that Iβm urging you to watch for yourself. Iβve put my main takeaways into some bullet points for you:
- RN is thriving: Over 2M weekly downloads of RN now, 30 shipped versions of RN in 2024 so far
- The new Architecture is now in Beta
- Expo is now officially recommended for all new apps
- New reactnative.dev landing page launched
- React Conf app is open source
- Expoβs vision for Universal RSC
- πΈ PowerSync - Supabase <> SQLite sync layer: follow our step-by-step video integration guide.
- π New React Native landing page
- π¦ New resources to get started with React Native and Expo: New landing page, new "Getting Started" docs, new Expo dev environment setup docs
- π¦ Interesting discussion on Apple's stance on server-driven UI in iOS apps: Will Universal RSC be a challenge in Appleβs App Store approval process?
- π¦ Potential ways to decrease Android bundle size: Two settings can significantly decrease bundle size, but - as always - this comes with trade-offs.
- π Chain React Conf - Portland, OR - July 17-19. The U.S. React Native Conference is back with engaging talks and hands-on workshops! Get 15% off your ticket with code βTWIRβ
- π Debunk ideas on cross-platform framework: Performance, Security, Accessibility, Stability, App Store acceptance, Native Features - all of these are sometimes mistakenly doubted when it comes to cross-platform apps.
- π Breaking down react-native-video 6.0.0 stable release - enhancements and comparisons
- π Creating Custom Fonts with React-Native-Skia
- π¦ Bootsplash v6 beta - Expo plugin, simpler setup: The React Conf app used it for splash screen!
- π¦ React Conf app open-sourced: Already uses React Compiler (Tweet)
- ποΈ RNR 297 - Jumping over the React Native v0.74 Bridge
- π₯ Supercharging your React Native app for Windows: React Native session at MS Build 2024
π Otherβ
- π What's new in the web - 12 newly available Baseline features
- π What's new in JavaScript Frameworks (May 2024)
- π Portable Server Rendered Web Components with Enhance SSR
- π ECMAScript 2023 feature: Symbols as WeakMap keys
- π¦ SolidStart 1.0 - The Shape of Frameworks to Come
- π¦ Graphql-query - 8.7x faster GraphQL query parser written in Rust
- π¦ Node 22.2
π€ Funβ
(Ok that React Compiler one is not technically accurate, but still fun π sorry Compiler team)
See ya! π
Don't miss the next email!