trpc
SKILL.md
tRPC Quick Start
Backend Router
import { initTRPC, TRPCError } from "@trpc/server";
import { z } from "zod";
export const t = initTRPC.create();
export const router = t.router;
export const publicProcedure = t.procedure;
export const myRouter = router({
getItem: publicProcedure
.input(z.object({ id: z.string() }))
.query(async ({ input }) => {
return await getItem(input.id);
}),
updateItem: publicProcedure
.input(z.object({ id: z.string(), data: z.any() }))
.mutation(async ({ input }) => {
return await updateItem(input.id, input.data);
}),
});
export const appRouter = router({
healthCheck: publicProcedure.query(() => "OK"),
my: myRouter,
});
export type AppRouter = typeof appRouter;
Frontend Client
import { createTRPCClient, httpBatchLink } from "@trpc/client";
import { createTRPCOptionsProxy } from "@trpc/tanstack-react-query";
import type { AppRouter } from "./path/to/router";
import { QueryClient } from "@tanstack/react-query";
export const queryClient = new QueryClient();
export const trpcClient = createTRPCClient<AppRouter>({
links: [httpBatchLink({ url: "/api/trpc" })],
});
export const trpc = createTRPCOptionsProxy<AppRouter>({
client: trpcClient,
queryClient,
});
Usage
const { data } = useQuery(trpc.my.getItem.queryOptions({ id }));
const mutation = useMutation(trpc.my.updateItem.mutationOptions());
Error Handling
throw new TRPCError({
code: "NOT_FOUND",
message: "Resource not found",
});
Advanced
- Subscriptions: See SUBSCRIPTIONS.md
- Server Adapters: See ADAPTERS.md
- Context: See CONTEXT.md
- Router Merging: See ROUTERS.md
- Middleware: See MIDDLEWARE.md
- Frontend Patterns: See FRONTEND.md
- Client Links: See LINKS.md
- Schemas: See SCHEMAS.md
- Client Errors: See CLIENT_ERRORS.md
- Install: See INSTALL.md
Weekly Installs
5
Repository
dimitrigilbert/ai-skillsGitHub Stars
2
First Seen
Feb 5, 2026
Security Audits
Installed on
opencode5
kilo5
gemini-cli5
claude-code5
github-copilot5
amp5