- 
                Notifications
    You must be signed in to change notification settings 
- Fork 107
Add serverSnapshot fallback to useSyncExternalStore #688
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
base: main
Are you sure you want to change the base?
Add serverSnapshot fallback to useSyncExternalStore #688
Conversation
Introduces a serverSnapshot object and passes it as the server snapshot function to useSyncExternalStore in useLiveQuery. This improves compatibility with server-side rendering by providing a default snapshot value.
| 
 | 
| More templates
 @tanstack/angular-db
 @tanstack/db
 @tanstack/db-ivm
 @tanstack/electric-db-collection
 @tanstack/query-db-collection
 @tanstack/react-db
 @tanstack/rxdb-db-collection
 @tanstack/solid-db
 @tanstack/svelte-db
 @tanstack/trailbase-db-collection
 @tanstack/vue-db
 commit:  | 
| Is this useful? I'm not sure I understand the point? You can't disable SSR in next.js? | 
| Disabling SSR in Next.js results in slower page loads, and dynamic imports requires a lot of DX overhead that is unnecessary. This also negatively impacts static export builds, since it prevents entire components from being rendered during the build phase if you put a dynamic client only import wrapper around it. | 
| The main purpose is to be able to have SSR rendered skeletons or  | 
| I'm slightly nervous of this change as it suggested DB is safe to use on SSR routes, but I fear that collection.preload() in a route loader is currently unsafe with a global collection. We need to check this though as is only a suspicion, it may just slow things down and not leak data. useLiveQuery being broken in SSR acts as a safeguard against this at the moment, until we fix SSR properly. | 
Introduces a serverSnapshot object and passes it as the server snapshot function to useSyncExternalStore in useLiveQuery. This improves compatibility with server-side rendering by providing a default snapshot value.
🎯 Changes
Fixes getServerSnapshot error on Next.js "use client" components without needing dynamic import.