Composables
It is often useful to wrap functionality of your @trpc/client
api within other functions. For this purpose, it's necessary to be able to infer input types and output types generated by your @trpc/server
router.
createTRPCNuxtClient already adds a
useQuery
method built on top of useAsyncData. You might not need this.Inference Helpers
@trpc/server
exports the following helper types to assist with inferring these types from the AppRouter
exported by your @trpc/server
router:
inferRouterInputs<TRouter>
inferRouterOutputs<TRouter>
Let's assume we have this example query wrapped within Nuxt's useAsyncData:
const { data, error } = await useAsyncData(() => $client.todo.getTodos.query())
We can wrap this in a composable and also set the client error types:
composables/useGetTodos.ts
import { TRPCClientError } from '@trpc/client'
import type { inferRouterOutputs } from '@trpc/server'
import type { AppRouter } from '@/server/trpc/routers'
type RouterOutput = inferRouterOutputs<AppRouter>
type GetTodosOutput = RouterOutput['todo']['getTodos']
type ErrorOutput = TRPCClientError<AppRouter>
export default function useGetTodos() {
const { $client } = useNuxtApp()
return useAsyncData<GetTodosOutput, ErrorOutput>(() => $client.todo.getTodos.query())
}
Now, we have a fully-typed composable.