[{"data":1,"prerenderedAt":2655},["ShallowReactive",2],{"navigation_docs":3,"-use-cases-client-logging":447,"-use-cases-client-logging-surround":2650},[4,30,80,245,361,416],{"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,353],{"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,"icon":261,"path":355,"stem":356,"children":357,"page":29},"Eve","\u002Fuse-cases\u002Feve","4.use-cases\u002F5.eve",[358],{"title":36,"path":359,"stem":360,"icon":261},"\u002Fuse-cases\u002Feve\u002Foverview","4.use-cases\u002F5.eve\u002F01.overview",{"title":362,"path":363,"stem":364,"children":365,"page":29},"Extend","\u002Fextend","5.extend",[366,370,375,380,385,389,393,397,401,406,411],{"title":36,"path":367,"stem":368,"icon":369},"\u002Fextend\u002Foverview","5.extend\u002F0.overview","i-lucide-blocks",{"title":371,"path":372,"stem":373,"icon":374},"Stream","\u002Fextend\u002Fstream","5.extend\u002F1.stream","i-lucide-radio-tower",{"title":376,"path":377,"stem":378,"icon":379},"Custom framework","\u002Fextend\u002Fcustom-framework","5.extend\u002F10.custom-framework","i-lucide-puzzle",{"title":381,"path":382,"stem":383,"icon":384},"FS reader","\u002Fextend\u002Ffs-reader","5.extend\u002F2.fs-reader","i-lucide-folder-search",{"title":345,"path":386,"stem":387,"icon":388},"\u002Fextend\u002Fconsumer-recipes","5.extend\u002F3.consumer-recipes","i-lucide-chef-hat",{"title":390,"path":391,"stem":392,"icon":369},"Plugins","\u002Fextend\u002Fplugins","5.extend\u002F4.plugins",{"title":394,"path":395,"stem":396,"icon":352},"Custom enrichers","\u002Fextend\u002Fcustom-enrichers","5.extend\u002F5.custom-enrichers",{"title":398,"path":399,"stem":400,"icon":64},"Tail sampling","\u002Fextend\u002Ftail-sampling","5.extend\u002F6.tail-sampling",{"title":402,"path":403,"stem":404,"icon":405},"Identity headers","\u002Fextend\u002Fidentity-headers","5.extend\u002F7.identity-headers","i-lucide-fingerprint",{"title":407,"path":408,"stem":409,"icon":410},"Custom drains","\u002Fextend\u002Fcustom-drains","5.extend\u002F8.custom-drains","i-lucide-share-2",{"title":412,"path":413,"stem":414,"icon":415},"Drain pipeline","\u002Fextend\u002Fdrain-pipeline","5.extend\u002F9.drain-pipeline","i-lucide-workflow",{"title":417,"path":418,"stem":419,"children":420,"page":29},"Reference","\u002Freference","6.reference",[421,426,429,434,438,443],{"title":422,"path":423,"stem":424,"icon":425},"Configuration","\u002Freference\u002Fconfiguration","6.reference\u002F1.configuration","i-lucide-settings",{"title":312,"path":427,"stem":428,"icon":315},"\u002Freference\u002Fperformance","6.reference\u002F2.performance",{"title":430,"path":431,"stem":432,"icon":433},"Vite Plugin","\u002Freference\u002Fvite-plugin","6.reference\u002F3.vite-plugin","i-custom-vite",{"title":435,"path":436,"stem":437,"icon":318},"Best Practices","\u002Freference\u002Fbest-practices","6.reference\u002F4.best-practices",{"title":439,"path":440,"stem":441,"icon":442},"vs Other Loggers","\u002Freference\u002Fvs-other-loggers","6.reference\u002F5.vs-other-loggers","i-lucide-scale",{"title":444,"path":445,"stem":446,"icon":352},"Agent Skills","\u002Freference\u002Fagent-skills","6.reference\u002F6.agent-skills",{"id":448,"title":255,"body":449,"description":2639,"extension":2640,"links":2641,"meta":2646,"navigation":2647,"path":256,"seo":2648,"stem":257,"__hash__":2649},"docs\u002F4.use-cases\u002F1.client-logging.md",{"type":450,"value":451,"toc":2622},"minimark",[452,456,459,503,507,510,1009,1015,1023,1047,1066,1076,1080,1085,1090,1096,1157,1215,1219,1222,1256,1272,1276,1293,1314,1318,1324,1459,1462,1465,1471,1586,1669,1682,1686,1689,1693,1707,2119,2127,2131,2138,2561,2564,2588,2596,2600,2618],[453,454,455],"p",{},"Server logs tell you what happened on the backend. Client logs complete the picture: user interactions, page views, frontend errors, and performance signals that never reach the server unless you capture them.",[457,458],"client-server-beacon",{},[460,461,464,467,489],"prompt",{":actions":462,"description":463,"icon":258},"[\"copy\",\"cursor\",\"windsurf\"]","Ship browser logs to my server",[453,465,466],{},"Ship browser logs to my server with evlog client logging.",[468,469,470,474,477,480,483,486],"ul",{},[471,472,473],"li",{},"Detect my framework (Nuxt, Next.js, SvelteKit, etc.) and pick the matching client entrypoint",[471,475,476],{},"Call initLog({ service: 'web' }) once at app start",[471,478,479],{},"Use log.info \u002F log.warn \u002F log.error in components, composables, and event handlers",[471,481,482],{},"Set user identity with setIdentity({ userId, email }) after login, clearIdentity() on logout",[471,484,485],{},"Enable transport in the framework config so logs POST to \u002Fapi\u002F_evlog\u002Fingest in batches",[471,487,488],{},"On the server, evlog auto-runs the drain pipeline on transported events with source: 'client'",[453,490,491,492,498,499],{},"Docs: ",[493,494,495],"a",{"href":495,"rel":496},"https:\u002F\u002Fwww.evlog.dev\u002Fuse-cases\u002Fclient-logging",[497],"nofollow","\nHTTP transport: ",[493,500,501],{"href":501,"rel":502},"https:\u002F\u002Fwww.evlog.dev\u002Fextend\u002Fdrain-pipeline",[497],[504,505,25],"h2",{"id":506},"quick-start",[453,508,509],{},"evlog provides a client-side logging API that works in any browser environment:",[511,512,513,692,910],"code-group",{},[514,515,521],"pre",{"className":516,"code":517,"filename":518,"language":519,"meta":520,"style":520},"language-typescript shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { initLog, log } from 'evlog\u002Fclient'\n\nexport default defineNuxtPlugin(() => {\n  initLog({ service: 'web' })\n\n  log.info({ action: 'app_init', path: window.location.pathname })\n})\n","app\u002Fplugins\u002Flogger.client.ts (Nuxt)","typescript","",[522,523,524,563,570,596,627,632,684],"code",{"__ignoreMap":520},[525,526,529,533,537,541,544,547,550,553,556,560],"span",{"class":527,"line":528},"line",1,[525,530,532],{"class":531},"s7zQu","import",[525,534,536],{"class":535},"sMK4o"," {",[525,538,540],{"class":539},"sTEyZ"," initLog",[525,542,543],{"class":535},",",[525,545,546],{"class":539}," log",[525,548,549],{"class":535}," }",[525,551,552],{"class":531}," from",[525,554,555],{"class":535}," '",[525,557,559],{"class":558},"sfazB","evlog\u002Fclient",[525,561,562],{"class":535},"'\n",[525,564,566],{"class":527,"line":565},2,[525,567,569],{"emptyLinePlaceholder":568},true,"\n",[525,571,573,576,579,583,586,589,593],{"class":527,"line":572},3,[525,574,575],{"class":531},"export",[525,577,578],{"class":531}," default",[525,580,582],{"class":581},"s2Zo4"," defineNuxtPlugin",[525,584,585],{"class":539},"(",[525,587,588],{"class":535},"()",[525,590,592],{"class":591},"spNyl"," =>",[525,594,595],{"class":535}," {\n",[525,597,599,602,605,608,611,614,616,619,622,624],{"class":527,"line":598},4,[525,600,601],{"class":581},"  initLog",[525,603,585],{"class":604},"swJcz",[525,606,607],{"class":535},"{",[525,609,610],{"class":604}," service",[525,612,613],{"class":535},":",[525,615,555],{"class":535},[525,617,618],{"class":558},"web",[525,620,621],{"class":535},"'",[525,623,549],{"class":535},[525,625,626],{"class":604},")\n",[525,628,630],{"class":527,"line":629},5,[525,631,569],{"emptyLinePlaceholder":568},[525,633,635,638,641,644,646,648,651,653,655,658,660,662,665,667,670,672,675,677,680,682],{"class":527,"line":634},6,[525,636,637],{"class":539},"  log",[525,639,640],{"class":535},".",[525,642,643],{"class":581},"info",[525,645,585],{"class":604},[525,647,607],{"class":535},[525,649,650],{"class":604}," action",[525,652,613],{"class":535},[525,654,555],{"class":535},[525,656,657],{"class":558},"app_init",[525,659,621],{"class":535},[525,661,543],{"class":535},[525,663,664],{"class":604}," path",[525,666,613],{"class":535},[525,668,669],{"class":539}," window",[525,671,640],{"class":535},[525,673,674],{"class":539},"location",[525,676,640],{"class":535},[525,678,679],{"class":539},"pathname",[525,681,549],{"class":535},[525,683,626],{"class":604},[525,685,687,690],{"class":527,"line":686},7,[525,688,689],{"class":535},"}",[525,691,626],{"class":539},[514,693,696],{"className":516,"code":694,"filename":695,"language":519,"meta":520,"style":520},"'use client'\nimport { useEffect } from 'react'\nimport { initLog, log } from 'evlog\u002Fclient'\n\nexport function LogProvider({ children }: { children: React.ReactNode }) {\n  useEffect(() => {\n    initLog({ service: 'web' })\n    log.info({ action: 'app_init', path: window.location.pathname })\n  }, [])\n\n  return \u003C>{children}\u003C\u002F>\n}\n","app\u002Fproviders.tsx (React \u002F Next.js)",[522,697,698,707,727,749,753,793,806,829,873,882,887,904],{"__ignoreMap":520},[525,699,700,702,705],{"class":527,"line":528},[525,701,621],{"class":535},[525,703,704],{"class":558},"use client",[525,706,562],{"class":535},[525,708,709,711,713,716,718,720,722,725],{"class":527,"line":565},[525,710,532],{"class":531},[525,712,536],{"class":535},[525,714,715],{"class":539}," useEffect",[525,717,549],{"class":535},[525,719,552],{"class":531},[525,721,555],{"class":535},[525,723,724],{"class":558},"react",[525,726,562],{"class":535},[525,728,729,731,733,735,737,739,741,743,745,747],{"class":527,"line":572},[525,730,532],{"class":531},[525,732,536],{"class":535},[525,734,540],{"class":539},[525,736,543],{"class":535},[525,738,546],{"class":539},[525,740,549],{"class":535},[525,742,552],{"class":531},[525,744,555],{"class":535},[525,746,559],{"class":558},[525,748,562],{"class":535},[525,750,751],{"class":527,"line":598},[525,752,569],{"emptyLinePlaceholder":568},[525,754,755,757,760,763,766,770,773,775,777,779,783,785,788,791],{"class":527,"line":629},[525,756,575],{"class":531},[525,758,759],{"class":591}," function",[525,761,762],{"class":581}," LogProvider",[525,764,765],{"class":535},"({",[525,767,769],{"class":768},"sHdIc"," children",[525,771,772],{"class":535}," }:",[525,774,536],{"class":535},[525,776,769],{"class":604},[525,778,613],{"class":535},[525,780,782],{"class":781},"sBMFI"," React",[525,784,640],{"class":535},[525,786,787],{"class":781},"ReactNode",[525,789,790],{"class":535}," })",[525,792,595],{"class":535},[525,794,795,798,800,802,804],{"class":527,"line":634},[525,796,797],{"class":581},"  useEffect",[525,799,585],{"class":604},[525,801,588],{"class":535},[525,803,592],{"class":591},[525,805,595],{"class":535},[525,807,808,811,813,815,817,819,821,823,825,827],{"class":527,"line":686},[525,809,810],{"class":581},"    initLog",[525,812,585],{"class":604},[525,814,607],{"class":535},[525,816,610],{"class":604},[525,818,613],{"class":535},[525,820,555],{"class":535},[525,822,618],{"class":558},[525,824,621],{"class":535},[525,826,549],{"class":535},[525,828,626],{"class":604},[525,830,832,835,837,839,841,843,845,847,849,851,853,855,857,859,861,863,865,867,869,871],{"class":527,"line":831},8,[525,833,834],{"class":539},"    log",[525,836,640],{"class":535},[525,838,643],{"class":581},[525,840,585],{"class":604},[525,842,607],{"class":535},[525,844,650],{"class":604},[525,846,613],{"class":535},[525,848,555],{"class":535},[525,850,657],{"class":558},[525,852,621],{"class":535},[525,854,543],{"class":535},[525,856,664],{"class":604},[525,858,613],{"class":535},[525,860,669],{"class":539},[525,862,640],{"class":535},[525,864,674],{"class":539},[525,866,640],{"class":535},[525,868,679],{"class":539},[525,870,549],{"class":535},[525,872,626],{"class":604},[525,874,876,879],{"class":527,"line":875},9,[525,877,878],{"class":535},"  },",[525,880,881],{"class":604}," [])\n",[525,883,885],{"class":527,"line":884},10,[525,886,569],{"emptyLinePlaceholder":568},[525,888,890,893,896,898,901],{"class":527,"line":889},11,[525,891,892],{"class":531},"  return",[525,894,895],{"class":604}," \u003C>",[525,897,607],{"class":535},[525,899,900],{"class":539},"children",[525,902,903],{"class":535},"}\u003C\u002F>\n",[525,905,907],{"class":527,"line":906},12,[525,908,909],{"class":535},"}\n",[514,911,914],{"className":516,"code":912,"filename":913,"language":519,"meta":520,"style":520},"import { initLog, log } from 'evlog\u002Fclient'\n\ninitLog({ service: 'web' })\nlog.info({ action: 'app_init', path: window.location.pathname })\n","src\u002Fapp.ts (Any frontend)",[522,915,916,938,942,965],{"__ignoreMap":520},[525,917,918,920,922,924,926,928,930,932,934,936],{"class":527,"line":528},[525,919,532],{"class":531},[525,921,536],{"class":535},[525,923,540],{"class":539},[525,925,543],{"class":535},[525,927,546],{"class":539},[525,929,549],{"class":535},[525,931,552],{"class":531},[525,933,555],{"class":535},[525,935,559],{"class":558},[525,937,562],{"class":535},[525,939,940],{"class":527,"line":565},[525,941,569],{"emptyLinePlaceholder":568},[525,943,944,947,949,951,953,955,957,959,961,963],{"class":527,"line":572},[525,945,946],{"class":581},"initLog",[525,948,585],{"class":539},[525,950,607],{"class":535},[525,952,610],{"class":604},[525,954,613],{"class":535},[525,956,555],{"class":535},[525,958,618],{"class":558},[525,960,621],{"class":535},[525,962,549],{"class":535},[525,964,626],{"class":539},[525,966,967,970,972,974,976,978,980,982,984,986,988,990,992,994,996,998,1000,1002,1005,1007],{"class":527,"line":598},[525,968,969],{"class":539},"log",[525,971,640],{"class":535},[525,973,643],{"class":581},[525,975,585],{"class":539},[525,977,607],{"class":535},[525,979,650],{"class":604},[525,981,613],{"class":535},[525,983,555],{"class":535},[525,985,657],{"class":558},[525,987,621],{"class":535},[525,989,543],{"class":535},[525,991,664],{"class":604},[525,993,613],{"class":535},[525,995,669],{"class":539},[525,997,640],{"class":535},[525,999,674],{"class":539},[525,1001,640],{"class":535},[525,1003,1004],{"class":539},"pathname ",[525,1006,689],{"class":535},[525,1008,626],{"class":539},[453,1010,1011,1012,1014],{},"The ",[522,1013,969],{}," object works anywhere in your client code: components, composables, event handlers.",[504,1016,1018,1019,1022],{"id":1017},"minimum-level-minlevel","Minimum level (",[522,1020,1021],{},"minLevel",")",[453,1024,1025,1026,1029,1030,1033,1034,1033,1036,1033,1039,1042,1043,1046],{},"Use ",[522,1027,1028],{},"initLog({ minLevel: 'warn' })"," to keep the browser console quiet (warnings and errors only). Severity order: ",[522,1031,1032],{},"debug"," \u003C ",[522,1035,643],{},[522,1037,1038],{},"warn",[522,1040,1041],{},"error",". Default is ",[522,1044,1045],{},"'debug'"," (all levels).",[453,1048,1049,1050,1054,1055,1058,1059,1062,1063,1065],{},"For a ",[1051,1052,1053],"strong",{},"debug toggle"," without reloading, call ",[522,1056,1057],{},"setMinLevel('debug')"," or ",[522,1060,1061],{},"setMinLevel('warn')"," from ",[522,1064,559],{}," when the user opts in or out of verbose logs.",[453,1067,1068,1070,1071,1075],{},[522,1069,1021],{}," applies to both console output and ",[493,1072,1074],{"href":1073},"#sending-logs-to-the-server","server transport"," payloads.",[504,1077,1079],{"id":1078},"two-call-signatures","Two Call Signatures",[453,1081,1011,1082,1084],{},[522,1083,969],{}," API accepts two forms depending on the context.",[1086,1087,1089],"h3",{"id":1088},"object-form-structured-context","Object Form (structured context)",[453,1091,1092,1093,613],{},"Pass an object to capture structured data, just like server-side ",[522,1094,1095],{},"log.set()",[514,1097,1100],{"className":516,"code":1098,"filename":1099,"language":519,"meta":520,"style":520},"log.info({ action: 'page_view', path: '\u002Fproducts', referrer: document.referrer })\n","pages\u002Fproducts.vue",[522,1101,1102],{"__ignoreMap":520},[525,1103,1104,1106,1108,1110,1112,1114,1116,1118,1120,1123,1125,1127,1129,1131,1133,1136,1138,1140,1143,1145,1148,1150,1153,1155],{"class":527,"line":528},[525,1105,969],{"class":539},[525,1107,640],{"class":535},[525,1109,643],{"class":581},[525,1111,585],{"class":539},[525,1113,607],{"class":535},[525,1115,650],{"class":604},[525,1117,613],{"class":535},[525,1119,555],{"class":535},[525,1121,1122],{"class":558},"page_view",[525,1124,621],{"class":535},[525,1126,543],{"class":535},[525,1128,664],{"class":604},[525,1130,613],{"class":535},[525,1132,555],{"class":535},[525,1134,1135],{"class":558},"\u002Fproducts",[525,1137,621],{"class":535},[525,1139,543],{"class":535},[525,1141,1142],{"class":604}," referrer",[525,1144,613],{"class":535},[525,1146,1147],{"class":539}," document",[525,1149,640],{"class":535},[525,1151,1152],{"class":539},"referrer ",[525,1154,689],{"class":535},[525,1156,626],{"class":539},[514,1158,1163],{"className":1159,"code":1160,"filename":1161,"language":1162,"meta":520,"style":520},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","[web] info  { action: 'page_view', path: '\u002Fproducts', referrer: 'https:\u002F\u002Fgoogle.com' }\n","Browser console","bash",[522,1164,1165],{"__ignoreMap":520},[525,1166,1167,1170,1172,1175,1178,1180,1183,1185,1187,1189,1191,1194,1196,1198,1200,1202,1205,1207,1210,1212],{"class":527,"line":528},[525,1168,1169],{"class":535},"[",[525,1171,618],{"class":539},[525,1173,1174],{"class":535},"]",[525,1176,1177],{"class":539}," info  ",[525,1179,607],{"class":535},[525,1181,1182],{"class":781}," action:",[525,1184,555],{"class":535},[525,1186,1122],{"class":558},[525,1188,621],{"class":535},[525,1190,543],{"class":558},[525,1192,1193],{"class":558}," path:",[525,1195,555],{"class":535},[525,1197,1135],{"class":558},[525,1199,621],{"class":535},[525,1201,543],{"class":558},[525,1203,1204],{"class":558}," referrer:",[525,1206,555],{"class":535},[525,1208,1209],{"class":558},"https:\u002F\u002Fgoogle.com",[525,1211,621],{"class":535},[525,1213,1214],{"class":558}," }\n",[1086,1216,1218],{"id":1217},"tag-message-form-quick-logs","Tag + Message Form (quick logs)",[453,1220,1221],{},"Pass a tag and a message for quick, readable logs:",[514,1223,1226],{"className":516,"code":1224,"filename":1225,"language":519,"meta":520,"style":520},"log.info('auth', 'User logged in')\n","composables\u002FuseAuth.ts",[522,1227,1228],{"__ignoreMap":520},[525,1229,1230,1232,1234,1236,1238,1240,1243,1245,1247,1249,1252,1254],{"class":527,"line":528},[525,1231,969],{"class":539},[525,1233,640],{"class":535},[525,1235,643],{"class":581},[525,1237,585],{"class":539},[525,1239,621],{"class":535},[525,1241,1242],{"class":558},"auth",[525,1244,621],{"class":535},[525,1246,543],{"class":535},[525,1248,555],{"class":535},[525,1250,1251],{"class":558},"User logged in",[525,1253,621],{"class":535},[525,1255,626],{"class":539},[514,1257,1259],{"className":1159,"code":1258,"filename":1161,"language":1162,"meta":520,"style":520},"[auth] User logged in\n",[522,1260,1261],{"__ignoreMap":520},[525,1262,1263,1265,1267,1269],{"class":527,"line":528},[525,1264,1169],{"class":535},[525,1266,1242],{"class":539},[525,1268,1174],{"class":535},[525,1270,1271],{"class":539}," User logged in\n",[1086,1273,1275],{"id":1274},"available-levels","Available Levels",[453,1277,1278,1279,1282,1283,1282,1286,1289,1290,640],{},"Both forms support four levels: ",[522,1280,1281],{},"log.info()",", ",[522,1284,1285],{},"log.warn()",[522,1287,1288],{},"log.error()",", and ",[522,1291,1292],{},"log.debug()",[453,1294,1295,1296,1298,1299,1302,1303,1306,1307,1310,1311,640],{},"In the browser, ",[522,1297,1292],{}," is emitted with ",[522,1300,1301],{},"console.log"," (not ",[522,1304,1305],{},"console.debug",") so lines stay visible with the default DevTools ",[1051,1308,1309],{},"Info"," filter; the structured event still has ",[522,1312,1313],{},"level: 'debug'",[504,1315,1317],{"id":1316},"identity-context","Identity Context",[453,1319,1320,1321,613],{},"Track which user generated a log with ",[522,1322,1323],{},"setIdentity()",[514,1325,1327],{"className":516,"code":1326,"filename":1225,"language":519,"meta":520,"style":520},"import { setIdentity, clearIdentity, log } from 'evlog\u002Fclient'\n\n\u002F\u002F After login\nsetIdentity({ userId: 'usr_123', plan: 'pro' })\n\nlog.info({ action: 'dashboard_view' })\n\u002F\u002F → { userId: 'usr_123', plan: 'pro', action: 'dashboard_view', ... }\n\n\u002F\u002F After logout\nclearIdentity()\n",[522,1328,1329,1357,1361,1367,1406,1410,1437,1442,1446,1451],{"__ignoreMap":520},[525,1330,1331,1333,1335,1338,1340,1343,1345,1347,1349,1351,1353,1355],{"class":527,"line":528},[525,1332,532],{"class":531},[525,1334,536],{"class":535},[525,1336,1337],{"class":539}," setIdentity",[525,1339,543],{"class":535},[525,1341,1342],{"class":539}," clearIdentity",[525,1344,543],{"class":535},[525,1346,546],{"class":539},[525,1348,549],{"class":535},[525,1350,552],{"class":531},[525,1352,555],{"class":535},[525,1354,559],{"class":558},[525,1356,562],{"class":535},[525,1358,1359],{"class":527,"line":565},[525,1360,569],{"emptyLinePlaceholder":568},[525,1362,1363],{"class":527,"line":572},[525,1364,1366],{"class":1365},"sHwdD","\u002F\u002F After login\n",[525,1368,1369,1372,1374,1376,1379,1381,1383,1386,1388,1390,1393,1395,1397,1400,1402,1404],{"class":527,"line":598},[525,1370,1371],{"class":581},"setIdentity",[525,1373,585],{"class":539},[525,1375,607],{"class":535},[525,1377,1378],{"class":604}," userId",[525,1380,613],{"class":535},[525,1382,555],{"class":535},[525,1384,1385],{"class":558},"usr_123",[525,1387,621],{"class":535},[525,1389,543],{"class":535},[525,1391,1392],{"class":604}," plan",[525,1394,613],{"class":535},[525,1396,555],{"class":535},[525,1398,1399],{"class":558},"pro",[525,1401,621],{"class":535},[525,1403,549],{"class":535},[525,1405,626],{"class":539},[525,1407,1408],{"class":527,"line":629},[525,1409,569],{"emptyLinePlaceholder":568},[525,1411,1412,1414,1416,1418,1420,1422,1424,1426,1428,1431,1433,1435],{"class":527,"line":634},[525,1413,969],{"class":539},[525,1415,640],{"class":535},[525,1417,643],{"class":581},[525,1419,585],{"class":539},[525,1421,607],{"class":535},[525,1423,650],{"class":604},[525,1425,613],{"class":535},[525,1427,555],{"class":535},[525,1429,1430],{"class":558},"dashboard_view",[525,1432,621],{"class":535},[525,1434,549],{"class":535},[525,1436,626],{"class":539},[525,1438,1439],{"class":527,"line":686},[525,1440,1441],{"class":1365},"\u002F\u002F → { userId: 'usr_123', plan: 'pro', action: 'dashboard_view', ... }\n",[525,1443,1444],{"class":527,"line":831},[525,1445,569],{"emptyLinePlaceholder":568},[525,1447,1448],{"class":527,"line":875},[525,1449,1450],{"class":1365},"\u002F\u002F After logout\n",[525,1452,1453,1456],{"class":527,"line":884},[525,1454,1455],{"class":581},"clearIdentity",[525,1457,1458],{"class":539},"()\n",[453,1460,1461],{},"Identity fields are automatically merged into every log event until cleared. This lets you correlate browser events to specific users in your observability tools.",[504,1463,422],{"id":1464},"configuration",[453,1466,1467,1470],{},[522,1468,1469],{},"initLog()"," accepts the following options:",[1472,1473,1474,1490],"table",{},[1475,1476,1477],"thead",{},[1478,1479,1480,1484,1487],"tr",{},[1481,1482,1483],"th",{},"Option",[1481,1485,1486],{},"Default",[1481,1488,1489],{},"Description",[1491,1492,1493,1509,1523,1537,1558,1573],"tbody",{},[1478,1494,1495,1501,1506],{},[1496,1497,1498],"td",{},[522,1499,1500],{},"enabled",[1496,1502,1503],{},[522,1504,1505],{},"true",[1496,1507,1508],{},"Enable or disable all client logging",[1478,1510,1511,1516,1520],{},[1496,1512,1513],{},[522,1514,1515],{},"console",[1496,1517,1518],{},[522,1519,1505],{},[1496,1521,1522],{},"Output logs to the browser console",[1478,1524,1525,1530,1534],{},[1496,1526,1527],{},[522,1528,1529],{},"pretty",[1496,1531,1532],{},[522,1533,1505],{},[1496,1535,1536],{},"Use colored, formatted console output",[1478,1538,1539,1543,1547],{},[1496,1540,1541],{},[522,1542,1021],{},[1496,1544,1545],{},[522,1546,1045],{},[1496,1548,1549,1550,1033,1552,1033,1554,1033,1556],{},"Minimum severity: ",[522,1551,1032],{},[522,1553,643],{},[522,1555,1038],{},[522,1557,1041],{},[1478,1559,1560,1565,1570],{},[1496,1561,1562],{},[522,1563,1564],{},"service",[1496,1566,1567],{},[522,1568,1569],{},"'client'",[1496,1571,1572],{},"Service name included in every log event",[1478,1574,1575,1580,1583],{},[1496,1576,1577],{},[522,1578,1579],{},"transport",[1496,1581,1582],{},"-",[1496,1584,1585],{},"Send logs to a server endpoint (see below)",[514,1587,1590],{"className":516,"code":1588,"filename":1589,"language":519,"meta":520,"style":520},"initLog({\n  service: 'web',\n  transport: {\n    enabled: true,\n    endpoint: '\u002Fapi\u002F_evlog\u002Fingest', \u002F\u002F default endpoint\n  },\n})\n","app\u002Fplugins\u002Flogger.client.ts",[522,1591,1592,1601,1617,1626,1639,1658,1663],{"__ignoreMap":520},[525,1593,1594,1596,1598],{"class":527,"line":528},[525,1595,946],{"class":581},[525,1597,585],{"class":539},[525,1599,1600],{"class":535},"{\n",[525,1602,1603,1606,1608,1610,1612,1614],{"class":527,"line":565},[525,1604,1605],{"class":604},"  service",[525,1607,613],{"class":535},[525,1609,555],{"class":535},[525,1611,618],{"class":558},[525,1613,621],{"class":535},[525,1615,1616],{"class":535},",\n",[525,1618,1619,1622,1624],{"class":527,"line":572},[525,1620,1621],{"class":604},"  transport",[525,1623,613],{"class":535},[525,1625,595],{"class":535},[525,1627,1628,1631,1633,1637],{"class":527,"line":598},[525,1629,1630],{"class":604},"    enabled",[525,1632,613],{"class":535},[525,1634,1636],{"class":1635},"sfNiH"," true",[525,1638,1616],{"class":535},[525,1640,1641,1644,1646,1648,1651,1653,1655],{"class":527,"line":629},[525,1642,1643],{"class":604},"    endpoint",[525,1645,613],{"class":535},[525,1647,555],{"class":535},[525,1649,1650],{"class":558},"\u002Fapi\u002F_evlog\u002Fingest",[525,1652,621],{"class":535},[525,1654,543],{"class":535},[525,1656,1657],{"class":1365}," \u002F\u002F default endpoint\n",[525,1659,1660],{"class":527,"line":634},[525,1661,1662],{"class":535},"  },\n",[525,1664,1665,1667],{"class":527,"line":686},[525,1666,689],{"class":535},[525,1668,626],{"class":539},[1670,1671,1672,1282,1674,1289,1676,1678,1679,1681],"callout",{"color":643,"icon":13},[522,1673,1500],{},[522,1675,1515],{},[522,1677,1529],{}," all default to ",[522,1680,1505],{},". You only need to set them if you want to change the defaults.",[504,1683,1685],{"id":1684},"sending-logs-to-the-server","Sending Logs to the Server",[453,1687,1688],{},"By default, client logs only appear in the browser console. To persist them, you have two options:",[1086,1690,1692],{"id":1691},"built-in-transport","Built-in Transport",[453,1694,1695,1696,1698,1699,1702,1703,1706],{},"The simplest approach is to enable the built-in transport in ",[522,1697,1469],{},". Each log is sent individually via ",[522,1700,1701],{},"fetch"," with ",[522,1704,1705],{},"keepalive: true",". Good for low-volume apps.",[511,1708,1709,1828,2028],{},[514,1710,1712],{"className":516,"code":1711,"filename":518,"language":519,"meta":520,"style":520},"import { initLog } from 'evlog\u002Fclient'\n\nexport default defineNuxtPlugin(() => {\n  initLog({\n    service: 'web',\n    transport: {\n      enabled: true,\n      endpoint: '\u002Fapi\u002F_evlog\u002Fingest',\n    },\n  })\n})\n",[522,1713,1714,1732,1736,1752,1760,1775,1784,1795,1810,1815,1822],{"__ignoreMap":520},[525,1715,1716,1718,1720,1722,1724,1726,1728,1730],{"class":527,"line":528},[525,1717,532],{"class":531},[525,1719,536],{"class":535},[525,1721,540],{"class":539},[525,1723,549],{"class":535},[525,1725,552],{"class":531},[525,1727,555],{"class":535},[525,1729,559],{"class":558},[525,1731,562],{"class":535},[525,1733,1734],{"class":527,"line":565},[525,1735,569],{"emptyLinePlaceholder":568},[525,1737,1738,1740,1742,1744,1746,1748,1750],{"class":527,"line":572},[525,1739,575],{"class":531},[525,1741,578],{"class":531},[525,1743,582],{"class":581},[525,1745,585],{"class":539},[525,1747,588],{"class":535},[525,1749,592],{"class":591},[525,1751,595],{"class":535},[525,1753,1754,1756,1758],{"class":527,"line":598},[525,1755,601],{"class":581},[525,1757,585],{"class":604},[525,1759,1600],{"class":535},[525,1761,1762,1765,1767,1769,1771,1773],{"class":527,"line":629},[525,1763,1764],{"class":604},"    service",[525,1766,613],{"class":535},[525,1768,555],{"class":535},[525,1770,618],{"class":558},[525,1772,621],{"class":535},[525,1774,1616],{"class":535},[525,1776,1777,1780,1782],{"class":527,"line":634},[525,1778,1779],{"class":604},"    transport",[525,1781,613],{"class":535},[525,1783,595],{"class":535},[525,1785,1786,1789,1791,1793],{"class":527,"line":686},[525,1787,1788],{"class":604},"      enabled",[525,1790,613],{"class":535},[525,1792,1636],{"class":1635},[525,1794,1616],{"class":535},[525,1796,1797,1800,1802,1804,1806,1808],{"class":527,"line":831},[525,1798,1799],{"class":604},"      endpoint",[525,1801,613],{"class":535},[525,1803,555],{"class":535},[525,1805,1650],{"class":558},[525,1807,621],{"class":535},[525,1809,1616],{"class":535},[525,1811,1812],{"class":527,"line":875},[525,1813,1814],{"class":535},"    },\n",[525,1816,1817,1820],{"class":527,"line":884},[525,1818,1819],{"class":535},"  }",[525,1821,626],{"class":604},[525,1823,1824,1826],{"class":527,"line":889},[525,1825,689],{"class":535},[525,1827,626],{"class":539},[514,1829,1834],{"className":1830,"code":1831,"filename":1832,"language":1833,"meta":520,"style":520},"language-tsx shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","import { EvlogProvider } from 'evlog\u002Fnext\u002Fclient'\n\nexport default function Layout({ children }: { children: React.ReactNode }) {\n  return (\n    \u003Chtml lang=\"en\">\n      \u003Cbody>\n        \u003CEvlogProvider service=\"web\" transport={{ enabled: true, endpoint: '\u002Fapi\u002F_evlog\u002Fingest' }}>\n          {children}\n        \u003C\u002FEvlogProvider>\n      \u003C\u002Fbody>\n    \u003C\u002Fhtml>\n  )\n}\n","app\u002Flayout.tsx (Next.js)","tsx",[522,1835,1836,1856,1860,1893,1900,1925,1935,1982,1991,2000,2009,2018,2023],{"__ignoreMap":520},[525,1837,1838,1840,1842,1845,1847,1849,1851,1854],{"class":527,"line":528},[525,1839,532],{"class":531},[525,1841,536],{"class":535},[525,1843,1844],{"class":539}," EvlogProvider",[525,1846,549],{"class":535},[525,1848,552],{"class":531},[525,1850,555],{"class":535},[525,1852,1853],{"class":558},"evlog\u002Fnext\u002Fclient",[525,1855,562],{"class":535},[525,1857,1858],{"class":527,"line":565},[525,1859,569],{"emptyLinePlaceholder":568},[525,1861,1862,1864,1866,1868,1871,1873,1875,1877,1879,1881,1883,1885,1887,1889,1891],{"class":527,"line":572},[525,1863,575],{"class":531},[525,1865,578],{"class":531},[525,1867,759],{"class":591},[525,1869,1870],{"class":581}," Layout",[525,1872,765],{"class":535},[525,1874,769],{"class":768},[525,1876,772],{"class":535},[525,1878,536],{"class":535},[525,1880,769],{"class":604},[525,1882,613],{"class":535},[525,1884,782],{"class":781},[525,1886,640],{"class":535},[525,1888,787],{"class":781},[525,1890,790],{"class":535},[525,1892,595],{"class":535},[525,1894,1895,1897],{"class":527,"line":598},[525,1896,892],{"class":531},[525,1898,1899],{"class":604}," (\n",[525,1901,1902,1905,1908,1911,1914,1917,1920,1922],{"class":527,"line":629},[525,1903,1904],{"class":535},"    \u003C",[525,1906,1907],{"class":604},"html",[525,1909,1910],{"class":591}," lang",[525,1912,1913],{"class":535},"=",[525,1915,1916],{"class":535},"\"",[525,1918,1919],{"class":558},"en",[525,1921,1916],{"class":535},[525,1923,1924],{"class":535},">\n",[525,1926,1927,1930,1933],{"class":527,"line":634},[525,1928,1929],{"class":535},"      \u003C",[525,1931,1932],{"class":604},"body",[525,1934,1924],{"class":535},[525,1936,1937,1940,1943,1945,1947,1949,1951,1953,1956,1959,1962,1964,1966,1968,1971,1973,1975,1977,1979],{"class":527,"line":686},[525,1938,1939],{"class":535},"        \u003C",[525,1941,1942],{"class":781},"EvlogProvider",[525,1944,610],{"class":591},[525,1946,1913],{"class":535},[525,1948,1916],{"class":535},[525,1950,618],{"class":558},[525,1952,1916],{"class":535},[525,1954,1955],{"class":591}," transport",[525,1957,1958],{"class":535},"={{",[525,1960,1961],{"class":604}," enabled",[525,1963,613],{"class":535},[525,1965,1636],{"class":1635},[525,1967,543],{"class":535},[525,1969,1970],{"class":604}," endpoint",[525,1972,613],{"class":535},[525,1974,555],{"class":535},[525,1976,1650],{"class":558},[525,1978,621],{"class":535},[525,1980,1981],{"class":535}," }}>\n",[525,1983,1984,1987,1989],{"class":527,"line":831},[525,1985,1986],{"class":535},"          {",[525,1988,900],{"class":539},[525,1990,909],{"class":535},[525,1992,1993,1996,1998],{"class":527,"line":875},[525,1994,1995],{"class":535},"        \u003C\u002F",[525,1997,1942],{"class":781},[525,1999,1924],{"class":535},[525,2001,2002,2005,2007],{"class":527,"line":884},[525,2003,2004],{"class":535},"      \u003C\u002F",[525,2006,1932],{"class":604},[525,2008,1924],{"class":535},[525,2010,2011,2014,2016],{"class":527,"line":889},[525,2012,2013],{"class":535},"    \u003C\u002F",[525,2015,1907],{"class":604},[525,2017,1924],{"class":535},[525,2019,2020],{"class":527,"line":906},[525,2021,2022],{"class":604},"  )\n",[525,2024,2026],{"class":527,"line":2025},13,[525,2027,909],{"class":535},[514,2029,2031],{"className":516,"code":2030,"filename":913,"language":519,"meta":520,"style":520},"import { initLog } from 'evlog\u002Fclient'\n\ninitLog({\n  service: 'web',\n  transport: {\n    enabled: true,\n    endpoint: '\u002Fapi\u002F_evlog\u002Fingest',\n  },\n})\n",[522,2032,2033,2051,2055,2063,2077,2085,2095,2109,2113],{"__ignoreMap":520},[525,2034,2035,2037,2039,2041,2043,2045,2047,2049],{"class":527,"line":528},[525,2036,532],{"class":531},[525,2038,536],{"class":535},[525,2040,540],{"class":539},[525,2042,549],{"class":535},[525,2044,552],{"class":531},[525,2046,555],{"class":535},[525,2048,559],{"class":558},[525,2050,562],{"class":535},[525,2052,2053],{"class":527,"line":565},[525,2054,569],{"emptyLinePlaceholder":568},[525,2056,2057,2059,2061],{"class":527,"line":572},[525,2058,946],{"class":581},[525,2060,585],{"class":539},[525,2062,1600],{"class":535},[525,2064,2065,2067,2069,2071,2073,2075],{"class":527,"line":598},[525,2066,1605],{"class":604},[525,2068,613],{"class":535},[525,2070,555],{"class":535},[525,2072,618],{"class":558},[525,2074,621],{"class":535},[525,2076,1616],{"class":535},[525,2078,2079,2081,2083],{"class":527,"line":629},[525,2080,1621],{"class":604},[525,2082,613],{"class":535},[525,2084,595],{"class":535},[525,2086,2087,2089,2091,2093],{"class":527,"line":634},[525,2088,1630],{"class":604},[525,2090,613],{"class":535},[525,2092,1636],{"class":1635},[525,2094,1616],{"class":535},[525,2096,2097,2099,2101,2103,2105,2107],{"class":527,"line":686},[525,2098,1643],{"class":604},[525,2100,613],{"class":535},[525,2102,555],{"class":535},[525,2104,1650],{"class":558},[525,2106,621],{"class":535},[525,2108,1616],{"class":535},[525,2110,2111],{"class":527,"line":831},[525,2112,1662],{"class":535},[525,2114,2115,2117],{"class":527,"line":875},[525,2116,689],{"class":535},[525,2118,626],{"class":539},[1670,2120,2121,2122,2126],{"color":643,"icon":13},"In Nuxt with the evlog module, the server ingest endpoint is auto-registered. For other frameworks, you need to create the endpoint yourself. See the ",[493,2123,2125],{"href":2124},"\u002Fextend\u002Fdrain-pipeline#server-endpoint","HTTP drain"," docs for Express and Hono examples.",[1086,2128,2130],{"id":2129},"http-drain-pipeline","HTTP drain pipeline",[453,2132,2133,2134,2137],{},"For higher volume or when you need batching, retries, and page-exit flushing, use the HTTP drain (",[522,2135,2136],{},"evlog\u002Fhttp","). This works with any frontend and has no framework dependency.",[511,2139,2140,2368],{},[514,2141,2143],{"className":516,"code":2142,"filename":518,"language":519,"meta":520,"style":520},"import { initLogger, log } from 'evlog'\nimport { createHttpLogDrain } from 'evlog\u002Fhttp'\n\nexport default defineNuxtPlugin(() => {\n  const drain = createHttpLogDrain({\n    drain: { endpoint: '\u002Fapi\u002F_evlog\u002Fingest' },\n    pipeline: {\n      batch: { size: 25, intervalMs: 2000 },\n      retry: { maxAttempts: 2 },\n    },\n  })\n\n  initLogger({ drain })\n  log.info({ action: 'app_init' })\n})\n",[522,2144,2145,2169,2188,2192,2208,2225,2247,2256,2286,2305,2309,2315,2319,2334,2361],{"__ignoreMap":520},[525,2146,2147,2149,2151,2154,2156,2158,2160,2162,2164,2167],{"class":527,"line":528},[525,2148,532],{"class":531},[525,2150,536],{"class":535},[525,2152,2153],{"class":539}," initLogger",[525,2155,543],{"class":535},[525,2157,546],{"class":539},[525,2159,549],{"class":535},[525,2161,552],{"class":531},[525,2163,555],{"class":535},[525,2165,2166],{"class":558},"evlog",[525,2168,562],{"class":535},[525,2170,2171,2173,2175,2178,2180,2182,2184,2186],{"class":527,"line":565},[525,2172,532],{"class":531},[525,2174,536],{"class":535},[525,2176,2177],{"class":539}," createHttpLogDrain",[525,2179,549],{"class":535},[525,2181,552],{"class":531},[525,2183,555],{"class":535},[525,2185,2136],{"class":558},[525,2187,562],{"class":535},[525,2189,2190],{"class":527,"line":572},[525,2191,569],{"emptyLinePlaceholder":568},[525,2193,2194,2196,2198,2200,2202,2204,2206],{"class":527,"line":598},[525,2195,575],{"class":531},[525,2197,578],{"class":531},[525,2199,582],{"class":581},[525,2201,585],{"class":539},[525,2203,588],{"class":535},[525,2205,592],{"class":591},[525,2207,595],{"class":535},[525,2209,2210,2213,2216,2219,2221,2223],{"class":527,"line":629},[525,2211,2212],{"class":591},"  const",[525,2214,2215],{"class":539}," drain",[525,2217,2218],{"class":535}," =",[525,2220,2177],{"class":581},[525,2222,585],{"class":604},[525,2224,1600],{"class":535},[525,2226,2227,2230,2232,2234,2236,2238,2240,2242,2244],{"class":527,"line":634},[525,2228,2229],{"class":604},"    drain",[525,2231,613],{"class":535},[525,2233,536],{"class":535},[525,2235,1970],{"class":604},[525,2237,613],{"class":535},[525,2239,555],{"class":535},[525,2241,1650],{"class":558},[525,2243,621],{"class":535},[525,2245,2246],{"class":535}," },\n",[525,2248,2249,2252,2254],{"class":527,"line":686},[525,2250,2251],{"class":604},"    pipeline",[525,2253,613],{"class":535},[525,2255,595],{"class":535},[525,2257,2258,2261,2263,2265,2268,2270,2274,2276,2279,2281,2284],{"class":527,"line":831},[525,2259,2260],{"class":604},"      batch",[525,2262,613],{"class":535},[525,2264,536],{"class":535},[525,2266,2267],{"class":604}," size",[525,2269,613],{"class":535},[525,2271,2273],{"class":2272},"sbssI"," 25",[525,2275,543],{"class":535},[525,2277,2278],{"class":604}," intervalMs",[525,2280,613],{"class":535},[525,2282,2283],{"class":2272}," 2000",[525,2285,2246],{"class":535},[525,2287,2288,2291,2293,2295,2298,2300,2303],{"class":527,"line":875},[525,2289,2290],{"class":604},"      retry",[525,2292,613],{"class":535},[525,2294,536],{"class":535},[525,2296,2297],{"class":604}," maxAttempts",[525,2299,613],{"class":535},[525,2301,2302],{"class":2272}," 2",[525,2304,2246],{"class":535},[525,2306,2307],{"class":527,"line":884},[525,2308,1814],{"class":535},[525,2310,2311,2313],{"class":527,"line":889},[525,2312,1819],{"class":535},[525,2314,626],{"class":604},[525,2316,2317],{"class":527,"line":906},[525,2318,569],{"emptyLinePlaceholder":568},[525,2320,2321,2324,2326,2328,2330,2332],{"class":527,"line":2025},[525,2322,2323],{"class":581},"  initLogger",[525,2325,585],{"class":604},[525,2327,607],{"class":535},[525,2329,2215],{"class":539},[525,2331,549],{"class":535},[525,2333,626],{"class":604},[525,2335,2337,2339,2341,2343,2345,2347,2349,2351,2353,2355,2357,2359],{"class":527,"line":2336},14,[525,2338,637],{"class":539},[525,2340,640],{"class":535},[525,2342,643],{"class":581},[525,2344,585],{"class":604},[525,2346,607],{"class":535},[525,2348,650],{"class":604},[525,2350,613],{"class":535},[525,2352,555],{"class":535},[525,2354,657],{"class":558},[525,2356,621],{"class":535},[525,2358,549],{"class":535},[525,2360,626],{"class":604},[525,2362,2364,2366],{"class":527,"line":2363},15,[525,2365,689],{"class":535},[525,2367,626],{"class":539},[514,2369,2371],{"className":516,"code":2370,"filename":913,"language":519,"meta":520,"style":520},"import { initLogger, log } from 'evlog'\nimport { createHttpLogDrain } from 'evlog\u002Fhttp'\n\nconst drain = createHttpLogDrain({\n  drain: { endpoint: 'https:\u002F\u002Flogs.example.com\u002Fv1\u002Fingest' },\n  pipeline: {\n    batch: { size: 25, intervalMs: 2000 },\n    retry: { maxAttempts: 2 },\n  },\n})\n\ninitLogger({ drain })\nlog.info({ action: 'app_init' })\n",[522,2372,2373,2395,2413,2417,2433,2455,2464,2489,2506,2510,2516,2520,2535],{"__ignoreMap":520},[525,2374,2375,2377,2379,2381,2383,2385,2387,2389,2391,2393],{"class":527,"line":528},[525,2376,532],{"class":531},[525,2378,536],{"class":535},[525,2380,2153],{"class":539},[525,2382,543],{"class":535},[525,2384,546],{"class":539},[525,2386,549],{"class":535},[525,2388,552],{"class":531},[525,2390,555],{"class":535},[525,2392,2166],{"class":558},[525,2394,562],{"class":535},[525,2396,2397,2399,2401,2403,2405,2407,2409,2411],{"class":527,"line":565},[525,2398,532],{"class":531},[525,2400,536],{"class":535},[525,2402,2177],{"class":539},[525,2404,549],{"class":535},[525,2406,552],{"class":531},[525,2408,555],{"class":535},[525,2410,2136],{"class":558},[525,2412,562],{"class":535},[525,2414,2415],{"class":527,"line":572},[525,2416,569],{"emptyLinePlaceholder":568},[525,2418,2419,2422,2425,2427,2429,2431],{"class":527,"line":598},[525,2420,2421],{"class":591},"const",[525,2423,2424],{"class":539}," drain ",[525,2426,1913],{"class":535},[525,2428,2177],{"class":581},[525,2430,585],{"class":539},[525,2432,1600],{"class":535},[525,2434,2435,2438,2440,2442,2444,2446,2448,2451,2453],{"class":527,"line":629},[525,2436,2437],{"class":604},"  drain",[525,2439,613],{"class":535},[525,2441,536],{"class":535},[525,2443,1970],{"class":604},[525,2445,613],{"class":535},[525,2447,555],{"class":535},[525,2449,2450],{"class":558},"https:\u002F\u002Flogs.example.com\u002Fv1\u002Fingest",[525,2452,621],{"class":535},[525,2454,2246],{"class":535},[525,2456,2457,2460,2462],{"class":527,"line":634},[525,2458,2459],{"class":604},"  pipeline",[525,2461,613],{"class":535},[525,2463,595],{"class":535},[525,2465,2466,2469,2471,2473,2475,2477,2479,2481,2483,2485,2487],{"class":527,"line":686},[525,2467,2468],{"class":604},"    batch",[525,2470,613],{"class":535},[525,2472,536],{"class":535},[525,2474,2267],{"class":604},[525,2476,613],{"class":535},[525,2478,2273],{"class":2272},[525,2480,543],{"class":535},[525,2482,2278],{"class":604},[525,2484,613],{"class":535},[525,2486,2283],{"class":2272},[525,2488,2246],{"class":535},[525,2490,2491,2494,2496,2498,2500,2502,2504],{"class":527,"line":831},[525,2492,2493],{"class":604},"    retry",[525,2495,613],{"class":535},[525,2497,536],{"class":535},[525,2499,2297],{"class":604},[525,2501,613],{"class":535},[525,2503,2302],{"class":2272},[525,2505,2246],{"class":535},[525,2507,2508],{"class":527,"line":875},[525,2509,1662],{"class":535},[525,2511,2512,2514],{"class":527,"line":884},[525,2513,689],{"class":535},[525,2515,626],{"class":539},[525,2517,2518],{"class":527,"line":889},[525,2519,569],{"emptyLinePlaceholder":568},[525,2521,2522,2525,2527,2529,2531,2533],{"class":527,"line":906},[525,2523,2524],{"class":581},"initLogger",[525,2526,585],{"class":539},[525,2528,607],{"class":535},[525,2530,2424],{"class":539},[525,2532,689],{"class":535},[525,2534,626],{"class":539},[525,2536,2537,2539,2541,2543,2545,2547,2549,2551,2553,2555,2557,2559],{"class":527,"line":2025},[525,2538,969],{"class":539},[525,2540,640],{"class":535},[525,2542,643],{"class":581},[525,2544,585],{"class":539},[525,2546,607],{"class":535},[525,2548,650],{"class":604},[525,2550,613],{"class":535},[525,2552,555],{"class":535},[525,2554,657],{"class":558},[525,2556,621],{"class":535},[525,2558,549],{"class":535},[525,2560,626],{"class":539},[453,2562,2563],{},"The HTTP drain automatically:",[468,2565,2566,2572,2578],{},[471,2567,2568,2571],{},[1051,2569,2570],{},"Batches"," events by size and time interval",[471,2573,2574,2577],{},[1051,2575,2576],{},"Retries"," failed sends with exponential backoff",[471,2579,2580,2583,2584,2587],{},[1051,2581,2582],{},"Flushes"," buffered events via ",[522,2585,2586],{},"sendBeacon"," when the page becomes hidden (tab switch, navigation, close)",[1670,2589,2592,2593,2595],{"color":2590,"icon":2591},"neutral","i-lucide-arrow-right","See the ",[493,2594,2125],{"href":413}," adapter docs for full configuration reference, authentication, and server endpoint examples.",[504,2597,2599],{"id":2598},"next-steps","Next Steps",[468,2601,2602,2607,2613],{},[471,2603,2604,2606],{},[493,2605,2125],{"href":413}," - Batching, retry, and sendBeacon fallback",[471,2608,2609,2612],{},[493,2610,2611],{"href":413},"Pipeline"," - Advanced pipeline configuration",[471,2614,2615,2617],{},[493,2616,51],{"href":52}," - Surface client errors with actionable context",[2619,2620,2621],"style",{},"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 .sfazB, html code.shiki .sfazB{--shiki-light:#91B859;--shiki-default:#C3E88D;--shiki-dark:#C3E88D}html pre.shiki code .s2Zo4, html code.shiki .s2Zo4{--shiki-light:#6182B8;--shiki-default:#82AAFF;--shiki-dark:#82AAFF}html pre.shiki code .spNyl, html code.shiki .spNyl{--shiki-light:#9C3EDA;--shiki-default:#C792EA;--shiki-dark:#C792EA}html pre.shiki code .swJcz, html code.shiki .swJcz{--shiki-light:#E53935;--shiki-default:#F07178;--shiki-dark:#F07178}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 .sHdIc, html code.shiki .sHdIc{--shiki-light:#90A4AE;--shiki-light-font-style:italic;--shiki-default:#EEFFFF;--shiki-default-font-style:italic;--shiki-dark:#BABED8;--shiki-dark-font-style:italic}html pre.shiki code .sBMFI, html code.shiki .sBMFI{--shiki-light:#E2931D;--shiki-default:#FFCB6B;--shiki-dark:#FFCB6B}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}html pre.shiki code .sbssI, html code.shiki .sbssI{--shiki-light:#F76D47;--shiki-default:#F78C6C;--shiki-dark:#F78C6C}",{"title":520,"searchDepth":565,"depth":565,"links":2623},[2624,2625,2627,2632,2633,2634,2638],{"id":506,"depth":565,"text":25},{"id":1017,"depth":565,"text":2626},"Minimum level (minLevel)",{"id":1078,"depth":565,"text":1079,"children":2628},[2629,2630,2631],{"id":1088,"depth":572,"text":1089},{"id":1217,"depth":572,"text":1218},{"id":1274,"depth":572,"text":1275},{"id":1316,"depth":565,"text":1317},{"id":1464,"depth":565,"text":422},{"id":1684,"depth":565,"text":1685,"children":2635},[2636,2637],{"id":1691,"depth":572,"text":1692},{"id":2129,"depth":572,"text":2130},{"id":2598,"depth":565,"text":2599},"Capture browser events with structured logging. Same API as the server, with automatic console styling, user identity context, and optional server transport.","md",[2642,2645],{"label":2125,"icon":2643,"to":413,"color":2590,"variant":2644},"i-lucide-globe","subtle",{"label":46,"icon":49,"to":47,"color":2590,"variant":2644},{},{"icon":258},{"title":255,"description":2639},"5o41RK22UBqd2WEjB2-NiwXE4g78DXbbNUqvo93Za4U",[2651,2653],{"title":36,"path":251,"stem":252,"description":2652,"icon":253,"children":-1},"Recipes that solve a specific problem with evlog — capture browser logs, observe AI SDK calls, identify users from Better Auth, build a tamper-evident audit trail, enrich every event with derived context.",{"title":36,"path":266,"stem":267,"description":2654,"icon":39,"children":-1},"Capture token usage, tool calls, model info, and streaming metrics from the Vercel AI SDK into wide events. Wrap your model and get full AI observability with one line.",1782924655737]