Files
tools/docs/nuxt.config.ts
T
robonen 8adc2522c6 docs: site WIP, extractor type cleanup, tests preset; add broadcastedRef
Type the docs extractor's package.json parsing as unknown; comment the Vite
plugin version-skew cast; wire the tests preset; site/architecture WIP.
2026-06-15 16:55:22 +07:00

86 lines
2.7 KiB
TypeScript

import { tmpdir } from 'node:os';
import tailwindcss from '@tailwindcss/vite';
// macOS dev fix: Nuxt's vite-node IPC uses a unix socket under $TMPDIR, and the
// default macOS temp dir (/var/folders/…) pushes the socket path past the
// ~104-char sun_path limit → `connect EINVAL` on every request. Point $TMPDIR
// at a short directory so `nuxt dev` works. Other platforms are unaffected.
if (process.platform === 'darwin' && tmpdir().length > 30)
process.env.TMPDIR = '/tmp';
export default defineNuxtConfig({
future: {
compatibilityVersion: 4,
},
modules: [
'@nuxt/fonts',
'./modules/extractor',
],
vite: {
plugins: [
// `as any`: @tailwindcss/vite and Nuxt resolve different `vite` versions, so
// their `Plugin` types are structurally identical but nominally incompatible.
tailwindcss() as any,
],
},
css: ['~/assets/css/main.css'],
ssr: true,
// Dev-only: the file-based payload cache collides on parent+child routes that
// share a segment (e.g. `/vue` is written as a file while `/vue/*` needs `vue`
// to be a directory → ENOTDIR). Production prerender writes each route to its
// own dir, so payload extraction is left enabled there.
$development: {
experimental: { payloadExtraction: false },
},
routeRules: {
'/**': { prerender: true },
// The MCP endpoint is a dynamic POST handler — never prerender it.
'/mcp': { prerender: false },
},
nitro: {
prerender: {
crawlLinks: true,
},
},
fonts: {
families: [
{ name: 'IBM Plex Sans', provider: 'google', weights: [400, 500, 600, 700] },
{ name: 'IBM Plex Mono', provider: 'google', weights: [400, 500, 600] },
{ name: 'Bricolage Grotesque', provider: 'google', weights: [600, 700, 800] },
],
},
app: {
pageTransition: { name: 'page', mode: 'out-in' },
head: {
title: '@robonen/tools — Documentation',
meta: [
{ name: 'description', content: 'Auto-generated documentation for the @robonen/tools monorepo' },
{ name: 'viewport', content: 'width=device-width, initial-scale=1' },
{ name: 'theme-color', content: '#faf8f3', media: '(prefers-color-scheme: light)' },
{ name: 'theme-color', content: '#161310', media: '(prefers-color-scheme: dark)' },
],
htmlAttrs: {
lang: 'en',
},
script: [
{
// Set the theme class before first paint to avoid a flash.
innerHTML: `(function(){try{var t=localStorage.getItem('docs-theme');var d=t==='dark'||((!t||t==='system')&&matchMedia('(prefers-color-scheme: dark)').matches);document.documentElement.classList.toggle('dark',d);}catch(e){}})();`,
tagPosition: 'head',
},
],
},
},
compatibilityDate: '2026-02-15',
});