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