Skip to content
This repository has been archived by the owner on Sep 28, 2024. It is now read-only.

trpc/use-client-stream-hydration

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Streamed hydration with "use client" components using @tanstack/react-query.

Demo: https://use-client-stream-hydration.vercel.app/

How this works

  • We use suspense: true in our useQuery()-calls
  • The API-requests from the useQuery-hooks get initialize on the server
  • We use Next.js' useServerInsertedHTML() to insert <script>-tags with dehydrated state of the request results.
  • The browser subscribes to the data changes in said <script>-tags and updates the React Query cache

Known limitations

  • If the browser tree re-renders while the data is fetching, we'll initialize the request in the browser
  • This is not "true" SSR and requires JS - the server does stream data to the browser, but if you View Source, you'll see that the DOM will only contain the suspense boundaries' fallbacks and not the DOM

Prior art

Releases

No releases published

Packages

No packages published