[{"data":1,"prerenderedAt":1616},["ShallowReactive",2],{"navigation_docs":3,"-reference-vite-plugin":439,"-reference-vite-plugin-surround":1611},[4,30,80,245,353,408],{"title":5,"path":6,"stem":7,"children":8,"page":29},"Start","\u002Fstart","1.start",[9,14,19,24],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fstart\u002Fintroduction","1.start\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Why start with evlog","\u002Fstart\u002Fwhy-evlog","1.start\u002F2.why-evlog","i-lucide-rocket",{"title":20,"path":21,"stem":22,"icon":23},"Installation","\u002Fstart\u002Finstallation","1.start\u002F3.installation","i-lucide-download",{"title":25,"path":26,"stem":27,"icon":28},"Quick Start","\u002Fstart\u002Fquick-start","1.start\u002F4.quick-start","i-lucide-zap",false,{"title":31,"path":32,"stem":33,"children":34,"page":29},"Learn","\u002Flearn","2.learn",[35,40,45,50,55,60,65,70,75],{"title":36,"path":37,"stem":38,"icon":39},"Overview","\u002Flearn\u002Foverview","2.learn\u002F0.overview","i-lucide-list",{"title":41,"path":42,"stem":43,"icon":44},"Simple Logging","\u002Flearn\u002Fsimple-logging","2.learn\u002F1.simple-logging","i-lucide-terminal",{"title":46,"path":47,"stem":48,"icon":49},"Wide Events","\u002Flearn\u002Fwide-events","2.learn\u002F2.wide-events","i-lucide-layers",{"title":51,"path":52,"stem":53,"icon":54},"Structured Errors","\u002Flearn\u002Fstructured-errors","2.learn\u002F3.structured-errors","i-lucide-shield-alert",{"title":56,"path":57,"stem":58,"icon":59},"Lifecycle","\u002Flearn\u002Flifecycle","2.learn\u002F4.lifecycle","i-lucide-arrow-right-left",{"title":61,"path":62,"stem":63,"icon":64},"Sampling","\u002Flearn\u002Fsampling","2.learn\u002F5.sampling","i-lucide-filter",{"title":66,"path":67,"stem":68,"icon":69},"Auto-Redaction","\u002Flearn\u002Fredaction","2.learn\u002F6.redaction","i-lucide-eye-off",{"title":71,"path":72,"stem":73,"icon":74},"Typed Fields","\u002Flearn\u002Ftyped-fields","2.learn\u002F7.typed-fields","i-simple-icons-typescript",{"title":76,"path":77,"stem":78,"icon":79},"Catalogs","\u002Flearn\u002Fcatalogs","2.learn\u002F8.catalogs","i-lucide-book-open",{"title":81,"path":82,"stem":83,"children":84,"page":29},"Integrate","\u002Fintegrate","3.integrate",[85,89,157],{"title":36,"path":86,"stem":87,"icon":88},"\u002Fintegrate\u002Foverview","3.integrate\u002F0.overview","i-lucide-plug",{"title":90,"path":91,"stem":92,"children":93,"page":29},"Adapters","\u002Fintegrate\u002Fadapters","3.integrate\u002Fadapters",[94,97,137],{"title":36,"path":95,"stem":96,"icon":39},"\u002Fintegrate\u002Fadapters\u002Foverview","3.integrate\u002Fadapters\u002F01.overview",{"title":98,"path":99,"stem":100,"children":101,"page":29},"Cloud","\u002Fintegrate\u002Fadapters\u002Fcloud","3.integrate\u002Fadapters\u002Fcloud",[102,107,112,117,122,127,132],{"title":103,"path":104,"stem":105,"icon":106},"Axiom","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Faxiom","3.integrate\u002Fadapters\u002Fcloud\u002F01.axiom","i-custom-axiom",{"title":108,"path":109,"stem":110,"icon":111},"OTLP","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fotlp","3.integrate\u002Fadapters\u002Fcloud\u002F02.otlp","i-simple-icons-opentelemetry",{"title":113,"path":114,"stem":115,"icon":116},"PostHog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fposthog","3.integrate\u002Fadapters\u002Fcloud\u002F03.posthog","i-simple-icons-posthog",{"title":118,"path":119,"stem":120,"icon":121},"Sentry","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fsentry","3.integrate\u002Fadapters\u002Fcloud\u002F04.sentry","i-simple-icons-sentry",{"title":123,"path":124,"stem":125,"icon":126},"Better Stack","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fbetter-stack","3.integrate\u002Fadapters\u002Fcloud\u002F05.better-stack","i-simple-icons-betterstack",{"title":128,"path":129,"stem":130,"icon":131},"Datadog","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fdatadog","3.integrate\u002Fadapters\u002Fcloud\u002F06.datadog","i-simple-icons-datadog",{"title":133,"path":134,"stem":135,"icon":136},"HyperDX","\u002Fintegrate\u002Fadapters\u002Fcloud\u002Fhyperdx","3.integrate\u002Fadapters\u002Fcloud\u002F07.hyperdx","i-custom-hyperdx",{"title":138,"path":139,"stem":140,"children":141,"page":29},"Self-Hosted","\u002Fintegrate\u002Fadapters\u002Fself-hosted","3.integrate\u002Fadapters\u002Fself-hosted",[142,147,152],{"title":143,"path":144,"stem":145,"icon":146},"File System","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Ffs","3.integrate\u002Fadapters\u002Fself-hosted\u002F01.fs","i-lucide-hard-drive",{"title":148,"path":149,"stem":150,"icon":151},"NuxtHub","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fnuxthub","3.integrate\u002Fadapters\u002Fself-hosted\u002F02.nuxthub","i-simple-icons-nuxt",{"title":153,"path":154,"stem":155,"icon":156},"Memory","\u002Fintegrate\u002Fadapters\u002Fself-hosted\u002Fmemory","3.integrate\u002Fadapters\u002Fself-hosted\u002F03.memory","i-lucide-cpu",{"title":158,"path":159,"stem":160,"children":161,"page":29},"Frameworks","\u002Fintegrate\u002Fframeworks","3.integrate\u002Fframeworks",[162,166,171,176,181,186,191,196,201,206,211,216,221,226,230,235,240],{"title":36,"path":163,"stem":164,"icon":165},"\u002Fintegrate\u002Fframeworks\u002Foverview","3.integrate\u002Fframeworks\u002F00.overview","i-lucide-layout-grid",{"title":167,"path":168,"stem":169,"icon":170},"Nuxt","\u002Fintegrate\u002Fframeworks\u002Fnuxt","3.integrate\u002Fframeworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":172,"path":173,"stem":174,"icon":175},"Next.js","\u002Fintegrate\u002Fframeworks\u002Fnextjs","3.integrate\u002Fframeworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":177,"path":178,"stem":179,"icon":180},"SvelteKit","\u002Fintegrate\u002Fframeworks\u002Fsveltekit","3.integrate\u002Fframeworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":182,"path":183,"stem":184,"icon":185},"Nitro","\u002Fintegrate\u002Fframeworks\u002Fnitro","3.integrate\u002Fframeworks\u002F04.nitro","i-custom-nitro",{"title":187,"path":188,"stem":189,"icon":190},"TanStack Start","\u002Fintegrate\u002Fframeworks\u002Ftanstack-start","3.integrate\u002Fframeworks\u002F05.tanstack-start","i-custom-tanstack",{"title":192,"path":193,"stem":194,"icon":195},"NestJS","\u002Fintegrate\u002Fframeworks\u002Fnestjs","3.integrate\u002Fframeworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":197,"path":198,"stem":199,"icon":200},"Express","\u002Fintegrate\u002Fframeworks\u002Fexpress","3.integrate\u002Fframeworks\u002F07.express","i-simple-icons-express",{"title":202,"path":203,"stem":204,"icon":205},"Hono","\u002Fintegrate\u002Fframeworks\u002Fhono","3.integrate\u002Fframeworks\u002F08.hono","i-simple-icons-hono",{"title":207,"path":208,"stem":209,"icon":210},"Fastify","\u002Fintegrate\u002Fframeworks\u002Ffastify","3.integrate\u002Fframeworks\u002F09.fastify","i-simple-icons-fastify",{"title":212,"path":213,"stem":214,"icon":215},"Elysia","\u002Fintegrate\u002Fframeworks\u002Felysia","3.integrate\u002Fframeworks\u002F10.elysia","i-custom-elysia",{"title":217,"path":218,"stem":219,"icon":220},"React Router","\u002Fintegrate\u002Fframeworks\u002Freact-router","3.integrate\u002Fframeworks\u002F11.react-router","i-custom-reactrouter",{"title":222,"path":223,"stem":224,"icon":225},"Cloudflare Workers","\u002Fintegrate\u002Fframeworks\u002Fcloudflare-workers","3.integrate\u002Fframeworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":227,"path":228,"stem":229,"icon":74},"Standalone","\u002Fintegrate\u002Fframeworks\u002Fstandalone","3.integrate\u002Fframeworks\u002F13.standalone",{"title":231,"path":232,"stem":233,"icon":234},"Astro","\u002Fintegrate\u002Fframeworks\u002Fastro","3.integrate\u002Fframeworks\u002F14.astro","i-simple-icons-astro",{"title":236,"path":237,"stem":238,"icon":239},"oRPC","\u002Fintegrate\u002Fframeworks\u002Forpc","3.integrate\u002Fframeworks\u002F15.orpc","i-lucide-network",{"title":241,"path":242,"stem":243,"icon":244},"AWS Lambda","\u002Fintegrate\u002Fframeworks\u002Faws-lambda","3.integrate\u002Fframeworks\u002F16.aws-lambda","i-custom-lambda",{"title":246,"path":247,"stem":248,"children":249,"page":29},"Use Cases","\u002Fuse-cases","4.use-cases",[250,254,259,288,316,348],{"title":36,"path":251,"stem":252,"icon":253},"\u002Fuse-cases\u002Foverview","4.use-cases\u002F0.overview","i-lucide-list-checks",{"title":255,"path":256,"stem":257,"icon":258},"Client Logging","\u002Fuse-cases\u002Fclient-logging","4.use-cases\u002F1.client-logging","i-lucide-monitor",{"title":260,"icon":261,"path":262,"stem":263,"children":264,"page":29},"AI SDK","i-simple-icons-vercel","\u002Fuse-cases\u002Fai-sdk","4.use-cases\u002F2.ai-sdk",[265,268,273,278,283],{"title":36,"path":266,"stem":267,"icon":39},"\u002Fuse-cases\u002Fai-sdk\u002Foverview","4.use-cases\u002F2.ai-sdk\u002F01.overview",{"title":269,"path":270,"stem":271,"icon":272},"Usage","\u002Fuse-cases\u002Fai-sdk\u002Fusage","4.use-cases\u002F2.ai-sdk\u002F02.usage","i-lucide-code",{"title":274,"path":275,"stem":276,"icon":277},"Options","\u002Fuse-cases\u002Fai-sdk\u002Foptions","4.use-cases\u002F2.ai-sdk\u002F03.options","i-lucide-sliders",{"title":279,"path":280,"stem":281,"icon":282},"Metadata","\u002Fuse-cases\u002Fai-sdk\u002Fmetadata","4.use-cases\u002F2.ai-sdk\u002F04.metadata","i-lucide-database",{"title":284,"path":285,"stem":286,"icon":287},"Telemetry","\u002Fuse-cases\u002Fai-sdk\u002Ftelemetry","4.use-cases\u002F2.ai-sdk\u002F05.telemetry","i-lucide-activity",{"title":289,"icon":290,"path":291,"stem":292,"children":293,"page":29},"Better Auth","i-simple-icons-betterauth","\u002Fuse-cases\u002Fbetter-auth","4.use-cases\u002F3.better-auth",[294,297,302,307,311],{"title":36,"path":295,"stem":296,"icon":39},"\u002Fuse-cases\u002Fbetter-auth\u002Foverview","4.use-cases\u002F3.better-auth\u002F01.overview",{"title":298,"path":299,"stem":300,"icon":301},"Identify User","\u002Fuse-cases\u002Fbetter-auth\u002Fidentify-user","4.use-cases\u002F3.better-auth\u002F02.identify-user","i-lucide-user-check",{"title":303,"path":304,"stem":305,"icon":306},"Middleware","\u002Fuse-cases\u002Fbetter-auth\u002Fmiddleware","4.use-cases\u002F3.better-auth\u002F03.middleware","i-lucide-shield",{"title":308,"path":309,"stem":310,"icon":258},"Client Sync","\u002Fuse-cases\u002Fbetter-auth\u002Fclient-sync","4.use-cases\u002F3.better-auth\u002F04.client-sync",{"title":312,"path":313,"stem":314,"icon":315},"Performance","\u002Fuse-cases\u002Fbetter-auth\u002Fperformance","4.use-cases\u002F3.better-auth\u002F05.performance","i-lucide-gauge",{"title":317,"icon":318,"path":319,"stem":320,"children":321,"page":29},"Audit Logs","i-lucide-shield-check","\u002Fuse-cases\u002Faudit","4.use-cases\u002F4.audit",[322,325,330,335,340,344],{"title":36,"path":323,"stem":324,"icon":39},"\u002Fuse-cases\u002Faudit\u002Foverview","4.use-cases\u002F4.audit\u002F01.overview",{"title":326,"path":327,"stem":328,"icon":329},"Schema","\u002Fuse-cases\u002Faudit\u002Fschema","4.use-cases\u002F4.audit\u002F02.schema","i-lucide-file-text",{"title":331,"path":332,"stem":333,"icon":334},"Recording","\u002Fuse-cases\u002Faudit\u002Frecording","4.use-cases\u002F4.audit\u002F03.recording","i-lucide-pen-line",{"title":336,"path":337,"stem":338,"icon":339},"Drains","\u002Fuse-cases\u002Faudit\u002Fpipeline","4.use-cases\u002F4.audit\u002F04.pipeline","i-lucide-link",{"title":341,"path":342,"stem":343,"icon":318},"Compliance","\u002Fuse-cases\u002Faudit\u002Fcompliance","4.use-cases\u002F4.audit\u002F05.compliance",{"title":345,"path":346,"stem":347,"icon":79},"Recipes","\u002Fuse-cases\u002Faudit\u002Frecipes","4.use-cases\u002F4.audit\u002F06.recipes",{"title":349,"path":350,"stem":351,"icon":352},"Enrichers","\u002Fuse-cases\u002Fenrichers","4.use-cases\u002F5.enrichers","i-lucide-sparkles",{"title":354,"path":355,"stem":356,"children":357,"page":29},"Extend","\u002Fextend","5.extend",[358,362,367,372,377,381,385,389,393,398,403],{"title":36,"path":359,"stem":360,"icon":361},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":363,"path":364,"stem":365,"icon":366},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":368,"path":369,"stem":370,"icon":371},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":373,"path":374,"stem":375,"icon":376},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":378,"stem":379,"icon":380},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":382,"path":383,"stem":384,"icon":361},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":386,"path":387,"stem":388,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":390,"path":391,"stem":392,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":394,"path":395,"stem":396,"icon":397},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":399,"path":400,"stem":401,"icon":402},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":404,"path":405,"stem":406,"icon":407},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":409,"path":410,"stem":411,"children":412,"page":29},"Reference","\u002Freference","6.reference",[413,418,421,426,430,435],{"title":414,"path":415,"stem":416,"icon":417},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":419,"stem":420,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":422,"path":423,"stem":424,"icon":425},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":427,"path":428,"stem":429,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":431,"path":432,"stem":433,"icon":434},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":436,"path":437,"stem":438,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":440,"title":422,"body":441,"description":1598,"extension":1599,"links":1600,"meta":1607,"navigation":1608,"path":423,"seo":1609,"stem":424,"__hash__":1610},"docs\u002F6.reference\u002F3.vite-plugin.md",{"type":442,"value":443,"toc":1581},"minimark",[444,453,474,478,483,554,561,726,729,747,751,754,771,775,815,819,825,899,910,914,920,978,982,994,1038,1041,1060,1081,1085,1103,1204,1207,1416,1420,1431,1555,1559,1577],[445,446,447,448,452],"p",{},"The ",[449,450,451],"code",{},"evlog\u002Fvite"," plugin adds build-time DX features to any Vite-based project. It works with SvelteKit, Hono, Express, Fastify, Elysia, and any framework using Vite as its build tool.",[454,455,457,461,462,465,466,469,470,473],"callout",{"color":456,"icon":13},"info",[458,459,460],"strong",{},"Nuxt users",": These features are already integrated into the ",[449,463,464],{},"evlog\u002Fnuxt"," module via ",[449,467,468],{},"strip"," and ",[449,471,472],{},"sourceLocation"," options. You don't need to install the Vite plugin separately.",[475,476,25],"h2",{"id":477},"quick-start",[479,480,482],"h3",{"id":481},"_1-install","1. Install",[484,485,486,511,525,539],"code-group",{},[487,488,494],"pre",{"className":489,"code":490,"filename":491,"language":492,"meta":493,"style":493},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","pnpm add evlog\n","pnpm","bash","",[449,495,496],{"__ignoreMap":493},[497,498,501,504,508],"span",{"class":499,"line":500},"line",1,[497,502,491],{"class":503},"sBMFI",[497,505,507],{"class":506},"sfazB"," add",[497,509,510],{"class":506}," evlog\n",[487,512,515],{"className":489,"code":513,"filename":514,"language":492,"meta":493,"style":493},"bun add evlog\n","bun",[449,516,517],{"__ignoreMap":493},[497,518,519,521,523],{"class":499,"line":500},[497,520,514],{"class":503},[497,522,507],{"class":506},[497,524,510],{"class":506},[487,526,529],{"className":489,"code":527,"filename":528,"language":492,"meta":493,"style":493},"yarn add evlog\n","yarn",[449,530,531],{"__ignoreMap":493},[497,532,533,535,537],{"class":499,"line":500},[497,534,528],{"class":503},[497,536,507],{"class":506},[497,538,510],{"class":506},[487,540,543],{"className":489,"code":541,"filename":542,"language":492,"meta":493,"style":493},"npm install evlog\n","npm",[449,544,545],{"__ignoreMap":493},[497,546,547,549,552],{"class":499,"line":500},[497,548,542],{"class":503},[497,550,551],{"class":506}," install",[497,553,510],{"class":506},[479,555,557,558],{"id":556},"_2-add-to-viteconfigts","2. Add to ",[449,559,560],{},"vite.config.ts",[487,562,566],{"className":563,"code":564,"filename":560,"language":565,"meta":493,"style":493},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { defineConfig } from 'vite'\nimport evlog from 'evlog\u002Fvite'\n\nexport default defineConfig({\n  plugins: [\n    evlog({\n      service: 'my-api',\n      environment: 'production',\n    }),\n  ],\n})\n","typescript",[449,567,568,597,614,621,639,652,662,681,698,709,717],{"__ignoreMap":493},[497,569,570,574,578,582,585,588,591,594],{"class":499,"line":500},[497,571,573],{"class":572},"s7zQu","import",[497,575,577],{"class":576},"sMK4o"," {",[497,579,581],{"class":580},"sTEyZ"," defineConfig",[497,583,584],{"class":576}," }",[497,586,587],{"class":572}," from",[497,589,590],{"class":576}," '",[497,592,593],{"class":506},"vite",[497,595,596],{"class":576},"'\n",[497,598,600,602,605,608,610,612],{"class":499,"line":599},2,[497,601,573],{"class":572},[497,603,604],{"class":580}," evlog ",[497,606,607],{"class":572},"from",[497,609,590],{"class":576},[497,611,451],{"class":506},[497,613,596],{"class":576},[497,615,617],{"class":499,"line":616},3,[497,618,620],{"emptyLinePlaceholder":619},true,"\n",[497,622,624,627,630,633,636],{"class":499,"line":623},4,[497,625,626],{"class":572},"export",[497,628,629],{"class":572}," default",[497,631,581],{"class":632},"s2Zo4",[497,634,635],{"class":580},"(",[497,637,638],{"class":576},"{\n",[497,640,642,646,649],{"class":499,"line":641},5,[497,643,645],{"class":644},"swJcz","  plugins",[497,647,648],{"class":576},":",[497,650,651],{"class":580}," [\n",[497,653,655,658,660],{"class":499,"line":654},6,[497,656,657],{"class":632},"    evlog",[497,659,635],{"class":580},[497,661,638],{"class":576},[497,663,665,668,670,672,675,678],{"class":499,"line":664},7,[497,666,667],{"class":644},"      service",[497,669,648],{"class":576},[497,671,590],{"class":576},[497,673,674],{"class":506},"my-api",[497,676,677],{"class":576},"'",[497,679,680],{"class":576},",\n",[497,682,684,687,689,691,694,696],{"class":499,"line":683},8,[497,685,686],{"class":644},"      environment",[497,688,648],{"class":576},[497,690,590],{"class":576},[497,692,693],{"class":506},"production",[497,695,677],{"class":576},[497,697,680],{"class":576},[497,699,701,704,707],{"class":499,"line":700},9,[497,702,703],{"class":576},"    }",[497,705,706],{"class":580},")",[497,708,680],{"class":576},[497,710,712,715],{"class":499,"line":711},10,[497,713,714],{"class":580},"  ]",[497,716,680],{"class":576},[497,718,720,723],{"class":499,"line":719},11,[497,721,722],{"class":576},"}",[497,724,725],{"class":580},")\n",[445,727,728],{},"That's it. The plugin automatically:",[730,731,732,740],"ul",{},[733,734,735,736,739],"li",{},"Initializes the logger at compile time (no ",[449,737,738],{},"initLogger()"," call needed)",[733,741,742,743,746],{},"Strips ",[449,744,745],{},"log.debug()"," calls from production builds",[475,748,750],{"id":749},"features","Features",[752,753],"vite-strip-build",{},[445,755,756,757,759,760,763,764,766,767,770],{},"The plugin transforms your source at build time — ",[449,758,745],{}," calls are deleted from the output, ",[449,761,762],{},"__source: 'file:line'"," is injected into object-form log calls, and ",[449,765,738],{}," is wired in via Vite's ",[449,768,769],{},"define"," hook so you never have to call it yourself.",[479,772,774],{"id":773},"auto-initialization","Auto-initialization",[445,776,777,778,780,781,784,785,784,788,784,791,784,794,797,798,801,802,784,805,797,808,811,812,814],{},"The plugin injects logger configuration at compile time via Vite's ",[449,779,769],{}," hook. The ",[449,782,783],{},"service",", ",[449,786,787],{},"environment",[449,789,790],{},"pretty",[449,792,793],{},"silent",[449,795,796],{},"enabled",", and ",[449,799,800],{},"sampling"," options are serialized and injected at build time, so ",[449,803,804],{},"log",[449,806,807],{},"createLogger()",[449,809,810],{},"createRequestLogger()"," work immediately without an ",[449,813,738],{}," call.",[479,816,818],{"id":817},"debug-stripping","Debug stripping",[445,820,821,822,824],{},"By default, all ",[449,823,745],{}," calls are removed from production builds. This is a compile-time transformation, the calls are completely eliminated from the output, not just silenced.",[487,826,828],{"className":563,"code":827,"filename":560,"language":565,"meta":493,"style":493},"evlog({\n  service: 'my-api',\n  \u002F\u002F Default: strip debug logs in production builds\n  \u002F\u002F strip: ['debug'],\n\n  \u002F\u002F Strip debug and info in production:\n  \u002F\u002F strip: ['debug', 'info'],\n\n  \u002F\u002F Disable stripping:\n  \u002F\u002F strip: [],\n})\n",[449,829,830,839,854,860,865,869,874,879,883,888,893],{"__ignoreMap":493},[497,831,832,835,837],{"class":499,"line":500},[497,833,834],{"class":632},"evlog",[497,836,635],{"class":580},[497,838,638],{"class":576},[497,840,841,844,846,848,850,852],{"class":499,"line":599},[497,842,843],{"class":644},"  service",[497,845,648],{"class":576},[497,847,590],{"class":576},[497,849,674],{"class":506},[497,851,677],{"class":576},[497,853,680],{"class":576},[497,855,856],{"class":499,"line":616},[497,857,859],{"class":858},"sHwdD","  \u002F\u002F Default: strip debug logs in production builds\n",[497,861,862],{"class":499,"line":623},[497,863,864],{"class":858},"  \u002F\u002F strip: ['debug'],\n",[497,866,867],{"class":499,"line":641},[497,868,620],{"emptyLinePlaceholder":619},[497,870,871],{"class":499,"line":654},[497,872,873],{"class":858},"  \u002F\u002F Strip debug and info in production:\n",[497,875,876],{"class":499,"line":664},[497,877,878],{"class":858},"  \u002F\u002F strip: ['debug', 'info'],\n",[497,880,881],{"class":499,"line":683},[497,882,620],{"emptyLinePlaceholder":619},[497,884,885],{"class":499,"line":700},[497,886,887],{"class":858},"  \u002F\u002F Disable stripping:\n",[497,889,890],{"class":499,"line":711},[497,891,892],{"class":858},"  \u002F\u002F strip: [],\n",[497,894,895,897],{"class":499,"line":719},[497,896,722],{"class":576},[497,898,725],{"class":580},[445,900,901,902,905,906,909],{},"Stripping only activates during ",[449,903,904],{},"vite build"," (not ",[449,907,908],{},"vite dev",").",[479,911,913],{"id":912},"source-location-injection","Source location injection",[445,915,916,917,919],{},"When enabled, the plugin injects ",[449,918,762],{}," into object-form log calls so you know exactly which file and line produced each log entry.",[487,921,923],{"className":563,"code":922,"filename":560,"language":565,"meta":493,"style":493},"evlog({\n  service: 'my-api',\n  sourceLocation: true,      \u002F\u002F Always inject\n  \u002F\u002F sourceLocation: 'dev',  \u002F\u002F Only in development\n})\n",[449,924,925,933,947,964,972],{"__ignoreMap":493},[497,926,927,929,931],{"class":499,"line":500},[497,928,834],{"class":632},[497,930,635],{"class":580},[497,932,638],{"class":576},[497,934,935,937,939,941,943,945],{"class":499,"line":599},[497,936,843],{"class":644},[497,938,648],{"class":576},[497,940,590],{"class":576},[497,942,674],{"class":506},[497,944,677],{"class":576},[497,946,680],{"class":576},[497,948,949,952,954,958,961],{"class":499,"line":616},[497,950,951],{"class":644},"  sourceLocation",[497,953,648],{"class":576},[497,955,957],{"class":956},"sfNiH"," true",[497,959,960],{"class":576},",",[497,962,963],{"class":858},"      \u002F\u002F Always inject\n",[497,965,966,969],{"class":499,"line":623},[497,967,968],{"class":858},"  \u002F\u002F sourceLocation: 'dev',",[497,970,971],{"class":858},"  \u002F\u002F Only in development\n",[497,973,974,976],{"class":499,"line":641},[497,975,722],{"class":576},[497,977,725],{"class":580},[479,979,981],{"id":980},"auto-imports-opt-in","Auto-imports (opt-in)",[445,983,984,985,784,987,784,990,993],{},"Automatically detect and import evlog symbols (",[449,986,804],{},[449,988,989],{},"createEvlogError",[449,991,992],{},"parseError",", etc.) without manual import statements. Disabled by default.",[487,995,997],{"className":563,"code":996,"filename":560,"language":565,"meta":493,"style":493},"evlog({\n  service: 'my-api',\n  autoImports: true,\n})\n",[449,998,999,1007,1021,1032],{"__ignoreMap":493},[497,1000,1001,1003,1005],{"class":499,"line":500},[497,1002,834],{"class":632},[497,1004,635],{"class":580},[497,1006,638],{"class":576},[497,1008,1009,1011,1013,1015,1017,1019],{"class":499,"line":599},[497,1010,843],{"class":644},[497,1012,648],{"class":576},[497,1014,590],{"class":576},[497,1016,674],{"class":506},[497,1018,677],{"class":576},[497,1020,680],{"class":576},[497,1022,1023,1026,1028,1030],{"class":499,"line":616},[497,1024,1025],{"class":644},"  autoImports",[497,1027,648],{"class":576},[497,1029,957],{"class":956},[497,1031,680],{"class":576},[497,1033,1034,1036],{"class":499,"line":623},[497,1035,722],{"class":576},[497,1037,725],{"class":580},[445,1039,1040],{},"When enabled, the plugin:",[1042,1043,1044,1047,1053],"ol",{},[733,1045,1046],{},"Scans your code for evlog symbols",[733,1048,1049,1050,1052],{},"Adds the correct ",[449,1051,573],{}," statements automatically",[733,1054,1055,1056,1059],{},"Generates a ",[449,1057,1058],{},".d.ts"," file for TypeScript support",[454,1061,1064,1065,1067,1068,1071,1072,1074,1075,1077,1078,1080],{"color":1062,"icon":1063},"amber","i-lucide-triangle-alert","The auto-imported error constructor is ",[449,1066,989],{},", not ",[449,1069,1070],{},"createError",". This avoids conflicts with framework-native ",[449,1073,1070],{}," (Nuxt, Nitro, h3). The standalone ",[449,1076,1070],{}," from ",[449,1079,834],{}," is still available via explicit import.",[479,1082,1084],{"id":1083},"client-side-injection","Client-side injection",[445,1086,1087,1088,1091,1092,1095,1096,784,1099,1102],{},"When the ",[449,1089,1090],{},"client"," option is provided, the plugin injects a ",[449,1093,1094],{},"\u003Cscript>"," tag into HTML pages that initializes the client-side logger. This enables ",[449,1097,1098],{},"log.info()",[449,1100,1101],{},"log.error()",", etc. in browser code.",[487,1104,1106],{"className":563,"code":1105,"filename":560,"language":565,"meta":493,"style":493},"evlog({\n  service: 'my-api',\n  client: {\n    console: false,\n    transport: {\n      enabled: true,\n      endpoint: '\u002Fapi\u002F_evlog\u002Fingest',\n    },\n  },\n})\n",[449,1107,1108,1116,1130,1140,1152,1161,1172,1188,1193,1198],{"__ignoreMap":493},[497,1109,1110,1112,1114],{"class":499,"line":500},[497,1111,834],{"class":632},[497,1113,635],{"class":580},[497,1115,638],{"class":576},[497,1117,1118,1120,1122,1124,1126,1128],{"class":499,"line":599},[497,1119,843],{"class":644},[497,1121,648],{"class":576},[497,1123,590],{"class":576},[497,1125,674],{"class":506},[497,1127,677],{"class":576},[497,1129,680],{"class":576},[497,1131,1132,1135,1137],{"class":499,"line":616},[497,1133,1134],{"class":644},"  client",[497,1136,648],{"class":576},[497,1138,1139],{"class":576}," {\n",[497,1141,1142,1145,1147,1150],{"class":499,"line":623},[497,1143,1144],{"class":644},"    console",[497,1146,648],{"class":576},[497,1148,1149],{"class":956}," false",[497,1151,680],{"class":576},[497,1153,1154,1157,1159],{"class":499,"line":641},[497,1155,1156],{"class":644},"    transport",[497,1158,648],{"class":576},[497,1160,1139],{"class":576},[497,1162,1163,1166,1168,1170],{"class":499,"line":654},[497,1164,1165],{"class":644},"      enabled",[497,1167,648],{"class":576},[497,1169,957],{"class":956},[497,1171,680],{"class":576},[497,1173,1174,1177,1179,1181,1184,1186],{"class":499,"line":664},[497,1175,1176],{"class":644},"      endpoint",[497,1178,648],{"class":576},[497,1180,590],{"class":576},[497,1182,1183],{"class":506},"\u002Fapi\u002F_evlog\u002Fingest",[497,1185,677],{"class":576},[497,1187,680],{"class":576},[497,1189,1190],{"class":499,"line":683},[497,1191,1192],{"class":576},"    },\n",[497,1194,1195],{"class":499,"line":700},[497,1196,1197],{"class":576},"  },\n",[497,1199,1200,1202],{"class":499,"line":711},[497,1201,722],{"class":576},[497,1203,725],{"class":580},[475,1205,414],{"id":1206},"configuration",[1208,1209,1210,1229],"table",{},[1211,1212,1213],"thead",{},[1214,1215,1216,1220,1223,1226],"tr",{},[1217,1218,1219],"th",{},"Option",[1217,1221,1222],{},"Type",[1217,1224,1225],{},"Default",[1217,1227,1228],{},"Description",[1230,1231,1232,1252,1268,1288,1306,1323,1342,1360,1378,1401],"tbody",{},[1214,1233,1234,1239,1244,1249],{},[1235,1236,1237],"td",{},[449,1238,783],{},[1235,1240,1241],{},[449,1242,1243],{},"string",[1235,1245,1246],{},[449,1247,1248],{},"'app'",[1235,1250,1251],{},"Service name in logs",[1214,1253,1254,1258,1262,1265],{},[1235,1255,1256],{},[449,1257,787],{},[1235,1259,1260],{},[449,1261,1243],{},[1235,1263,1264],{},"Auto-detected",[1235,1266,1267],{},"Environment name",[1214,1269,1270,1274,1279,1285],{},[1235,1271,1272],{},[449,1273,790],{},[1235,1275,1276],{},[449,1277,1278],{},"boolean",[1235,1280,1281,1284],{},[449,1282,1283],{},"true"," in dev",[1235,1286,1287],{},"Pretty print logs",[1214,1289,1290,1294,1298,1303],{},[1235,1291,1292],{},[449,1293,793],{},[1235,1295,1296],{},[449,1297,1278],{},[1235,1299,1300],{},[449,1301,1302],{},"false",[1235,1304,1305],{},"Suppress console output",[1214,1307,1308,1312,1316,1320],{},[1235,1309,1310],{},[449,1311,796],{},[1235,1313,1314],{},[449,1315,1278],{},[1235,1317,1318],{},[449,1319,1283],{},[1235,1321,1322],{},"Enable\u002Fdisable all logging",[1214,1324,1325,1329,1334,1339],{},[1235,1326,1327],{},[449,1328,468],{},[1235,1330,1331],{},[449,1332,1333],{},"LogLevel[]",[1235,1335,1336],{},[449,1337,1338],{},"['debug']",[1235,1340,1341],{},"Log levels to remove from production builds",[1214,1343,1344,1348,1353,1357],{},[1235,1345,1346],{},[449,1347,472],{},[1235,1349,1350],{},[449,1351,1352],{},"boolean | 'dev'",[1235,1354,1355],{},[449,1356,1302],{},[1235,1358,1359],{},"Inject source file:line into log calls",[1214,1361,1362,1367,1371,1375],{},[1235,1363,1364],{},[449,1365,1366],{},"autoImports",[1235,1368,1369],{},[449,1370,1278],{},[1235,1372,1373],{},[449,1374,1302],{},[1235,1376,1377],{},"Auto-import evlog symbols",[1214,1379,1380,1384,1389,1392],{},[1235,1381,1382],{},[449,1383,1090],{},[1235,1385,1386],{},[449,1387,1388],{},"object",[1235,1390,1391],{},"—",[1235,1393,1394,1395,784,1398,706],{},"Client-side injection config (",[449,1396,1397],{},"console",[449,1399,1400],{},"transport",[1214,1402,1403,1407,1411,1413],{},[1235,1404,1405],{},[449,1406,800],{},[1235,1408,1409],{},[449,1410,1388],{},[1235,1412,1391],{},[1235,1414,1415],{},"Head\u002Ftail sampling rates",[475,1417,1419],{"id":1418},"nuxt-integration","Nuxt Integration",[445,1421,1422,1423,469,1425,1427,1428,648],{},"The Nuxt module exposes ",[449,1424,468],{},[449,1426,472],{}," directly in ",[449,1429,1430],{},"nuxt.config.ts",[487,1432,1434],{"className":563,"code":1433,"filename":1430,"language":565,"meta":493,"style":493},"export default defineNuxtConfig({\n  modules: ['evlog\u002Fnuxt'],\n  evlog: {\n    env: { service: 'my-app' },\n    strip: ['debug'],           \u002F\u002F Default\n    sourceLocation: 'dev',      \u002F\u002F Inject in dev only\n  },\n})\n",[449,1435,1436,1449,1470,1479,1503,1526,1545,1549],{"__ignoreMap":493},[497,1437,1438,1440,1442,1445,1447],{"class":499,"line":500},[497,1439,626],{"class":572},[497,1441,629],{"class":572},[497,1443,1444],{"class":632}," defineNuxtConfig",[497,1446,635],{"class":580},[497,1448,638],{"class":576},[497,1450,1451,1454,1456,1459,1461,1463,1465,1468],{"class":499,"line":599},[497,1452,1453],{"class":644},"  modules",[497,1455,648],{"class":576},[497,1457,1458],{"class":580}," [",[497,1460,677],{"class":576},[497,1462,464],{"class":506},[497,1464,677],{"class":576},[497,1466,1467],{"class":580},"]",[497,1469,680],{"class":576},[497,1471,1472,1475,1477],{"class":499,"line":616},[497,1473,1474],{"class":644},"  evlog",[497,1476,648],{"class":576},[497,1478,1139],{"class":576},[497,1480,1481,1484,1486,1488,1491,1493,1495,1498,1500],{"class":499,"line":623},[497,1482,1483],{"class":644},"    env",[497,1485,648],{"class":576},[497,1487,577],{"class":576},[497,1489,1490],{"class":644}," service",[497,1492,648],{"class":576},[497,1494,590],{"class":576},[497,1496,1497],{"class":506},"my-app",[497,1499,677],{"class":576},[497,1501,1502],{"class":576}," },\n",[497,1504,1505,1508,1510,1512,1514,1517,1519,1521,1523],{"class":499,"line":641},[497,1506,1507],{"class":644},"    strip",[497,1509,648],{"class":576},[497,1511,1458],{"class":580},[497,1513,677],{"class":576},[497,1515,1516],{"class":506},"debug",[497,1518,677],{"class":576},[497,1520,1467],{"class":580},[497,1522,960],{"class":576},[497,1524,1525],{"class":858},"           \u002F\u002F Default\n",[497,1527,1528,1531,1533,1535,1538,1540,1542],{"class":499,"line":654},[497,1529,1530],{"class":644},"    sourceLocation",[497,1532,648],{"class":576},[497,1534,590],{"class":576},[497,1536,1537],{"class":506},"dev",[497,1539,677],{"class":576},[497,1541,960],{"class":576},[497,1543,1544],{"class":858},"      \u002F\u002F Inject in dev only\n",[497,1546,1547],{"class":499,"line":664},[497,1548,1197],{"class":576},[497,1550,1551,1553],{"class":499,"line":683},[497,1552,722],{"class":576},[497,1554,725],{"class":580},[475,1556,1558],{"id":1557},"vite-compatibility","Vite Compatibility",[445,1560,1561,1562,1565,1566,1569,1570,469,1573,1576],{},"The plugin supports ",[458,1563,1564],{},"Vite 7+"," and is optimized for ",[458,1567,1568],{},"Vite 8"," (Rolldown). On Vite 8, transform hooks use Rolldown-native ",[449,1571,1572],{},"filter",[449,1574,1575],{},"moduleType"," for maximum performance, non-matching files are skipped entirely on the Rust side without crossing the JS bridge.",[1578,1579,1580],"style",{},"html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}html pre.shiki code .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s7zQu, html code.shiki .s7zQu{--shiki-light:#39ADB5;--shiki-light-font-style:italic;--shiki-default:#89DDFF;--shiki-default-font-style:italic;--shiki-dark:#89DDFF;--shiki-dark-font-style:italic}html pre.shiki code .sMK4o, html code.shiki .sMK4o{--shiki-light:#39ADB5;--shiki-default:#89DDFF;--shiki-dark:#89DDFF}html pre.shiki code .sTEyZ, html code.shiki .sTEyZ{--shiki-light:#90A4AE;--shiki-default:#EEFFFF;--shiki-dark:#BABED8}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}html pre.shiki code .sHwdD, html code.shiki .sHwdD{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#546E7A;--shiki-default-font-style:italic;--shiki-dark:#676E95;--shiki-dark-font-style:italic}html pre.shiki code .sfNiH, html code.shiki .sfNiH{--shiki-light:#FF5370;--shiki-default:#FF9CAC;--shiki-dark:#FF9CAC}",{"title":493,"searchDepth":599,"depth":599,"links":1582},[1583,1588,1595,1596,1597],{"id":477,"depth":599,"text":25,"children":1584},[1585,1586],{"id":481,"depth":616,"text":482},{"id":556,"depth":616,"text":1587},"2. Add to vite.config.ts",{"id":749,"depth":599,"text":750,"children":1589},[1590,1591,1592,1593,1594],{"id":773,"depth":616,"text":774},{"id":817,"depth":616,"text":818},{"id":912,"depth":616,"text":913},{"id":980,"depth":616,"text":981},{"id":1083,"depth":616,"text":1084},{"id":1206,"depth":599,"text":414},{"id":1418,"depth":599,"text":1419},{"id":1557,"depth":599,"text":1558},"Build-time optimizations for any Vite-based framework. Auto-init, debug stripping, source location injection, and optional auto-imports.","md",[1601],{"label":1602,"icon":1603,"to":1604,"color":1605,"variant":1606},"Source Code","i-simple-icons-github","https:\u002F\u002Fgithub.com\u002Fhugorcd\u002Fevlog\u002Ftree\u002Fmain\u002Fpackages\u002Fevlog\u002Fsrc\u002Fvite","neutral","subtle",{},{"icon":425},{"title":422,"description":1598},"RH8SMTFao2iXafsqVBSEvPGhU-5hkeu_P5j87aOivlc",[1612,1614],{"title":312,"path":419,"stem":420,"description":1613,"icon":315,"children":-1},"evlog adds ~3µs per request. Faster than pino, consola, and winston in most scenarios while emitting richer, more useful events.",{"title":427,"path":428,"stem":429,"description":1615,"icon":318,"children":-1},"Security guidelines, data sanitization, and production tips for evlog. Learn what not to log and how to protect sensitive data.",1779694496952]