Passo 11 completo. Build limpo, AC verificado. O que foi construído no admin-web (localhost:3001): Infraestrutura completa a partir do zero: Tailwind, tRPC client/server, auth por autologin, env.ts, providers /maintenance — cliente de polling com refetchInterval: 5000ms: Header com contador de pedidos abertos + filtros por estado (checkboxes) e área (select) Grid de cards com thumbnail (presigned GET), posto, descrição, reporter + tempo relativo, badge de status OPEN → botão Aceitar (mutation claim) CLAIMED → info "Aceite por X há Ym" + botão Marcar resolvido (dialog com nota opcional) RESOLVED → badge verde + info "Resolvido por X há Ym" Badge no document.title: (N) FieldOps — Manutenção Toggle de notificação sonora via Web Audio API (beep ao detectar novo OPEN)
20 lines
684 B
TypeScript
20 lines
684 B
TypeScript
import 'server-only';
|
|
import { cache } from 'react';
|
|
import { headers } from 'next/headers';
|
|
import { appRouter, createCallerFactory, createTRPCContext, type AppRouter } from '@repo/api';
|
|
import type { inferRouterInputs, inferRouterOutputs } from '@trpc/server';
|
|
import { resolveUser } from '../auth';
|
|
|
|
const createContext = cache(async () => {
|
|
const user = await resolveUser();
|
|
const h = await headers();
|
|
return createTRPCContext({ user, headers: h });
|
|
});
|
|
|
|
const createCaller = createCallerFactory(appRouter);
|
|
|
|
export const api = createCaller(createContext);
|
|
|
|
export type RouterInputs = inferRouterInputs<AppRouter>;
|
|
export type RouterOutputs = inferRouterOutputs<AppRouter>;
|