mirror of
https://github.com/documenso/documenso.git
synced 2025-11-13 16:23:06 +10:00
## Description Add support to develop without network access since TRPC by default will prevent network requests when offline. https://tanstack.com/query/v4/docs/framework/react/guides/network-mode#network-mode-always ## Changes Made - Add dynamic logic to toggle offline development - Removed teams feature flag
71 lines
1.7 KiB
TypeScript
71 lines
1.7 KiB
TypeScript
'use client';
|
|
|
|
import { useState } from 'react';
|
|
|
|
import type { QueryClientConfig } from '@tanstack/react-query';
|
|
import { QueryClient, QueryClientProvider } from '@tanstack/react-query';
|
|
import { httpBatchLink } from '@trpc/client';
|
|
import { createTRPCReact } from '@trpc/react-query';
|
|
import SuperJSON from 'superjson';
|
|
|
|
import { getBaseUrl } from '@documenso/lib/universal/get-base-url';
|
|
|
|
import type { AppRouter } from '../server/router';
|
|
|
|
export const trpc = createTRPCReact<AppRouter>({
|
|
unstable_overrides: {
|
|
useMutation: {
|
|
async onSuccess(opts) {
|
|
await opts.originalFn();
|
|
await opts.queryClient.invalidateQueries();
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
export interface TrpcProviderProps {
|
|
children: React.ReactNode;
|
|
}
|
|
|
|
export function TrpcProvider({ children }: TrpcProviderProps) {
|
|
let queryClientConfig: QueryClientConfig | undefined;
|
|
|
|
const isDevelopingOffline =
|
|
typeof window !== 'undefined' &&
|
|
window.location.hostname === 'localhost' &&
|
|
!window.navigator.onLine;
|
|
|
|
if (isDevelopingOffline) {
|
|
queryClientConfig = {
|
|
defaultOptions: {
|
|
queries: {
|
|
networkMode: 'always',
|
|
},
|
|
mutations: {
|
|
networkMode: 'always',
|
|
},
|
|
},
|
|
};
|
|
}
|
|
|
|
const [queryClient] = useState(() => new QueryClient(queryClientConfig));
|
|
|
|
const [trpcClient] = useState(() =>
|
|
trpc.createClient({
|
|
transformer: SuperJSON,
|
|
|
|
links: [
|
|
httpBatchLink({
|
|
url: `${getBaseUrl()}/api/trpc`,
|
|
}),
|
|
],
|
|
}),
|
|
);
|
|
|
|
return (
|
|
<trpc.Provider client={trpcClient} queryClient={queryClient}>
|
|
<QueryClientProvider client={queryClient}>{children}</QueryClientProvider>
|
|
</trpc.Provider>
|
|
);
|
|
}
|