-
Notifications
You must be signed in to change notification settings - Fork 6
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
Integrate SSR with React #69
Comments
Hello @ngbrown , The difference between the SSR, the JS, the React and the Node SDK is basically http request handling and cache handling. The JS SDK uses XMLHttpRequest to fetch the config.json from our servers and a localstorage+inmemory cache implementation by default. So the SSR SDK can work in client-side and server-side scenarios too, but it wasn't designed to provide a bridge between server-side and client-side. I hope I could help. Cheers, |
@laliconfigcat Thanks for the response and the clarification on the differences between SSR and Node.js on the server side. I hope this provides some insperation for what others might want a bridge between server-side and client-side or future guidance on the ConfigCat libraries. This SSR library seems to be the most reasonable place to handle this situation because that's where developers would most likely want to bridge the two. To avoid a React hydration error on the client side, we can't wait for an Async http call to finish. |
We recently introduced synchronous feature flag evaluation in our SDKS with the help of snapshots. Could that help you in the hydration error on client-side? https://configcat.com/docs/sdk-reference/js-ssr/#snapshots-and-synchronous-feature-flag-evaluation |
@laliconfigcat I saw the documentation for the snapshot, but I also saw that getting a specific value for a specific user was after the snapshot. I mentioned that the user identification value was on the server-side, so I don't think the snapshot would prove useful in this case.
|
This issue is marked stale because it has no activity in the last 3 weeks. The issue will be closed in one week. Please remove the stale flag to keep it open. |
Is your feature request related to a problem? Please describe.
There are three configcat JS libraries, and the advantage of the SSR one over Node.js or React isn't clear. In my case, I'm using Remix, and the user ID is entirely on the server within the cookie derived session. I need the React.js render to match on both the server and client side.
Describe the solution you'd like
I would like a set of React components that can take the ConfigCat values passed from a server route loader and initialize the context of the react components.
Describe alternatives you've considered
I considered the react library, but like I mentioned, the client-side doesn't have a copy of the user-id. Passing it would expose the app to unnecessary data leakage.
I considered the Node.js library, but I didn't see the differences spelled out. While I'm running Remix on Node.js, it could run on other JavaScript engines like Cloudflare Workers.
Using the SSR library to as documented doesn't provide a clear way to optionally render UI components in a consistent manner between the server and client. I need the server to get the flags for the logged-in user and then both use them when rendering to HTML and distribute the settings to the client so it can also use the values while rendering.
Additional context
I wrote two files to aid me in this:
configcat.server.ts
:and
configcat.tsx
:And use like this:
The text was updated successfully, but these errors were encountered: