Spaces:
Runtime error
Runtime error
/** | |
* This is the client-side entrypoint for your tRPC API. | |
* It's used to create the `api` object which contains the Next.js App-wrapper | |
* as well as your typesafe react-query hooks. | |
* | |
* We also create a few inference helpers for input and output types | |
*/ | |
import { httpBatchLink, loggerLink } from "@trpc/client"; | |
import { createTRPCNext } from "@trpc/next"; | |
import { type inferRouterInputs, type inferRouterOutputs } from "@trpc/server"; | |
import superjson from "superjson"; | |
import { type AppRouter } from "../server/api/root"; | |
const getBaseUrl = () => { | |
if (typeof window !== "undefined") return ""; // browser should use relative url | |
if (process.env.VERCEL_URL) return `https://${process.env.VERCEL_URL}`; // SSR should use vercel url | |
return `http://localhost:${process.env.PORT ?? 3000}`; // dev SSR should use localhost | |
}; | |
/** | |
* A set of typesafe react-query hooks for your tRPC API | |
*/ | |
export const api = createTRPCNext<AppRouter>({ | |
config() { | |
return { | |
/** | |
* Transformer used for data de-serialization from the server | |
* @see https://trpc.io/docs/data-transformers | |
**/ | |
transformer: superjson, | |
/** | |
* Links used to determine request flow from client to server | |
* @see https://trpc.io/docs/links | |
* */ | |
links: [ | |
loggerLink({ | |
enabled: (opts) => | |
process.env.NODE_ENV === "development" || | |
(opts.direction === "down" && opts.result instanceof Error), | |
}), | |
httpBatchLink({ | |
url: `${getBaseUrl()}/api/trpc`, | |
}), | |
], | |
}; | |
}, | |
/** | |
* Whether tRPC should await queries when server rendering pages | |
* @see https://trpc.io/docs/nextjs#ssr-boolean-default-false | |
*/ | |
ssr: false, | |
}); | |
/** | |
* Inference helper for inputs | |
* @example type HelloInput = RouterInputs['example']['hello'] | |
**/ | |
export type RouterInputs = inferRouterInputs<AppRouter>; | |
/** | |
* Inference helper for outputs | |
* @example type HelloOutput = RouterOutputs['example']['hello'] | |
**/ | |
export type RouterOutputs = inferRouterOutputs<AppRouter>; | |