mirror of
https://github.com/langgenius/dify.git
synced 2026-06-21 01:41:08 +08:00
Co-authored-by: zhangx1n <zhangxin@dify.ai> Co-authored-by: yyh <yuanyouhuilyz@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
43 lines
1.1 KiB
TypeScript
43 lines
1.1 KiB
TypeScript
'use client'
|
|
|
|
import type { QueryClient } from '@tanstack/react-query'
|
|
import { QueryClientProvider } from '@tanstack/react-query'
|
|
import { queryClientAtom } from 'jotai-tanstack-query'
|
|
import { useHydrateAtoms } from 'jotai/react/utils'
|
|
import { isServer } from '@/utils/client'
|
|
import { makeQueryClient } from './query-client-server'
|
|
|
|
let browserQueryClient: QueryClient | undefined
|
|
|
|
function getQueryClient() {
|
|
if (isServer) {
|
|
return makeQueryClient()
|
|
}
|
|
if (!browserQueryClient)
|
|
browserQueryClient = makeQueryClient()
|
|
return browserQueryClient
|
|
}
|
|
|
|
export const TanstackQueryInitializer = ({ children }: { children: React.ReactNode }) => {
|
|
const queryClient = getQueryClient()
|
|
return (
|
|
<QueryClientProvider client={queryClient}>
|
|
<HydrateJotaiQueryClient queryClient={queryClient}>
|
|
{children}
|
|
</HydrateJotaiQueryClient>
|
|
</QueryClientProvider>
|
|
)
|
|
}
|
|
|
|
function HydrateJotaiQueryClient({
|
|
children,
|
|
queryClient,
|
|
}: {
|
|
children: React.ReactNode
|
|
queryClient: QueryClient
|
|
}) {
|
|
useHydrateAtoms(new Map([[queryClientAtom, queryClient]]))
|
|
|
|
return children
|
|
}
|