Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/thomasballinger/convex-react-query-draft
https://github.com/thomasballinger/convex-react-query-draft
Last synced: 20 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/thomasballinger/convex-react-query-draft
- Owner: thomasballinger
- Created: 2024-06-25T00:00:31.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-08T23:17:31.000Z (6 months ago)
- Last Synced: 2024-12-16T13:43:19.910Z (26 days ago)
- Language: TypeScript
- Size: 65.4 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Convex <3s TanStack Query
Want to use Convex in an app that uses React Query?
Convex is a database with server-side (db-side? like stored procedures) functions that update reactively.
Instead of polling you subscribe to receive update from these server-side query functions.All relevant subscriptions will be pushed to the client and updated at the same time so data is never stale and there's no need to call `queryClient.invalidateQueries()`.
## Setup
See [./src/example.tsx](./src/example.tsx) for a real example. The general pattern:
1. Create a ConvexClient and ConvexQueryClient. Set a global default `queryKeyHashFn` of `convexQueryKeyHashFn`.
```ts
const convexClient = new ConvexReactClient(import.meta.env.VITE_CONVEX_URL);
const convexQueryClient = new ConvexQueryClient(convexClient);
const queryClient = new QueryClient({
defaultOptions: {
queries: {
queryKeyHashFn: convexQueryKeyHashFn,
queryFn: convexQueryClient.queryFn,
},
},
});
convexQueryClient.connect(queryClient);
```2. Use `useQuery()` with the `queryOptions` method of `convexQueryClient` on an `api` object imported from `../convex/_generated/server` and the arguments for this query function.
These two form the query key.```ts
const { isPending, error, data } = useQuery({
...convexQueryOptions(api.repos.get, { repo: "made/up" }),
gcTime: 10000, // unsubscribe after 10s of no use
});
````staleTime` is set to `Infinity` beacuse this data is never stale; it's proactively updated whenever the query result updates on the server. (see [tkdodo's post](https://tkdodo.eu/blog/using-web-sockets-with-react-query#increasing-staletime)
for more about this)
If you like, customize the `gcTime` to the length of time a query subscription should remain active after all `useQuery()` hooks using it have unmounted.# Differences from using TanStack Query with `fetch`
New query results are pushed from the server, so a `staleTime` of `Infinity` should be used.
Your app will remain subscribed to a query until the `gcTime` has elapsed. Tune this for your app: it's a good idea to
use a value of at last a couple secondisFetching will always be `false` because there's no lag between
# Example
To run this example:
- `npm install`
- `npm run dev`# Authentication (example TODO)
TanStack Query isn't opionated about auth; an auth code might be a an element of a query key like any other.
With Convex it's not necessary to add an additional key for an auth code; auth is an implicit argument to all
Convex queries and these queries will be retried when authentication info changes.Convex auth is typically done via JWT: some query functions will fail if requested before calling `convexReactClinet.setAuth()` with a function that
provides the token.Auth setup looks just like it's recommended in [Convex docs](https://docs.convex.dev/auth), which make use of components that use native convex hooks.
For Clerk, this might look like this: a `ClerkProvider` for auth, a `ConvexProviderWithClerk` for the convex client, and a `QueryClient`.```
```
See the [Convex Auth docs](https://docs.convex.dev/auth) for setup instructions.
# TODO
- auth
- paginated queries
- cleanup / unsubscribe in useEffect; something with hot reloading may not be working right# Contributing
After cloning this repo run `npm i` to install dependencies.
This package uses [tshy](https://github.com/isaacs/tshy) to publish ESM and CJS builds.