import { fileURLToPath } from 'url' import { join, resolve } from 'pathe' import { defu } from 'defu' import dedent from 'dedent' import { addImports, addPlugin, addServerHandler, addTemplate, defineNuxtModule } from '@nuxt/kit' export interface ModuleOptions { baseURL: string endpoint: string } export default defineNuxtModule({ meta: { name: 'trpc-nuxt', configKey: 'trpc', }, defaults: { baseURL: 'http://localhost:3000', endpoint: '/trpc', }, async setup(options, nuxt) { const runtimeDir = fileURLToPath(new URL('./runtime', import.meta.url)) nuxt.options.build.transpile.push(runtimeDir, '#build/trpc-handler') const handlerPath = join(nuxt.options.buildDir, 'trpc-handler.ts') const trpcOptionsPath = join(nuxt.options.srcDir, 'server/trpc') // Final resolved configuration const finalConfig = nuxt.options.runtimeConfig.public.trpc = defu(nuxt.options.runtimeConfig.public.trpc, { baseURL: options.baseURL, endpoint: options.endpoint, }) addImports([ { name: 'useClient', from: join(runtimeDir, 'client') }, { name: 'useAsyncQuery', from: join(runtimeDir, 'client') }, { name: 'useClientHeaders', from: join(runtimeDir, 'client') }, { name: 'getQueryKey', from: join(runtimeDir, 'client') }, ]) addServerHandler({ route: `${finalConfig.endpoint}/*`, handler: handlerPath, }) addPlugin(resolve(runtimeDir, 'plugin')) addTemplate({ filename: 'trpc-handler.ts', write: true, getContents() { return dedent` import { createTRPCHandler } from 'trpc-nuxt/api' import * as functions from '${trpcOptionsPath}' export default createTRPCHandler({ ...functions, endpoint: '${finalConfig.endpoint}' }) ` }, }) }, })