[{"data":1,"prerenderedAt":727},["ShallowReactive",2],{"navigation_docs":3,"-getting-started-agent-skills":263,"-getting-started-agent-skills-surround":722},[4,30,115,174,233,249],{"title":5,"path":6,"stem":7,"children":8,"page":29},"Getting Started","\u002Fgetting-started","1.getting-started",[9,14,19,24],{"title":10,"path":11,"stem":12,"icon":13},"Introduction","\u002Fgetting-started\u002Fintroduction","1.getting-started\u002F1.introduction","i-lucide-info",{"title":15,"path":16,"stem":17,"icon":18},"Installation","\u002Fgetting-started\u002Finstallation","1.getting-started\u002F2.installation","i-lucide-download",{"title":20,"path":21,"stem":22,"icon":23},"Quick Start","\u002Fgetting-started\u002Fquick-start","1.getting-started\u002F3.quick-start","i-lucide-zap",{"title":25,"path":26,"stem":27,"icon":28},"Agent Skills","\u002Fgetting-started\u002Fagent-skills","1.getting-started\u002F4.agent-skills","i-lucide-sparkles",false,{"title":31,"path":32,"stem":33,"children":34,"page":29},"Frameworks","\u002Fframeworks","2.frameworks",[35,40,45,50,55,60,65,70,75,80,85,90,95,100,105,110],{"title":36,"path":37,"stem":38,"icon":39},"Overview","\u002Fframeworks\u002Foverview","2.frameworks\u002F00.overview","i-lucide-layout-grid",{"title":41,"path":42,"stem":43,"icon":44},"Nuxt","\u002Fframeworks\u002Fnuxt","2.frameworks\u002F01.nuxt","i-simple-icons-nuxtdotjs",{"title":46,"path":47,"stem":48,"icon":49},"Next.js","\u002Fframeworks\u002Fnextjs","2.frameworks\u002F02.nextjs","i-simple-icons-nextdotjs",{"title":51,"path":52,"stem":53,"icon":54},"SvelteKit","\u002Fframeworks\u002Fsveltekit","2.frameworks\u002F03.sveltekit","i-simple-icons-svelte",{"title":56,"path":57,"stem":58,"icon":59},"Nitro","\u002Fframeworks\u002Fnitro","2.frameworks\u002F04.nitro","i-custom-nitro",{"title":61,"path":62,"stem":63,"icon":64},"TanStack Start","\u002Fframeworks\u002Ftanstack-start","2.frameworks\u002F05.tanstack-start","i-custom-tanstack",{"title":66,"path":67,"stem":68,"icon":69},"NestJS","\u002Fframeworks\u002Fnestjs","2.frameworks\u002F06.nestjs","i-simple-icons-nestjs",{"title":71,"path":72,"stem":73,"icon":74},"Express","\u002Fframeworks\u002Fexpress","2.frameworks\u002F07.express","i-simple-icons-express",{"title":76,"path":77,"stem":78,"icon":79},"Hono","\u002Fframeworks\u002Fhono","2.frameworks\u002F08.hono","i-simple-icons-hono",{"title":81,"path":82,"stem":83,"icon":84},"Fastify","\u002Fframeworks\u002Ffastify","2.frameworks\u002F09.fastify","i-simple-icons-fastify",{"title":86,"path":87,"stem":88,"icon":89},"Elysia","\u002Fframeworks\u002Felysia","2.frameworks\u002F10.elysia","i-custom-elysia",{"title":91,"path":92,"stem":93,"icon":94},"React Router","\u002Fframeworks\u002Freact-router","2.frameworks\u002F11.react-router","i-simple-icons-reactrouter",{"title":96,"path":97,"stem":98,"icon":99},"Cloudflare Workers","\u002Fframeworks\u002Fcloudflare-workers","2.frameworks\u002F12.cloudflare-workers","i-simple-icons-cloudflare",{"title":101,"path":102,"stem":103,"icon":104},"Standalone","\u002Fframeworks\u002Fstandalone","2.frameworks\u002F13.standalone","i-simple-icons-typescript",{"title":106,"path":107,"stem":108,"icon":109},"Astro","\u002Fframeworks\u002Fastro","2.frameworks\u002F14.astro","i-simple-icons-astro",{"title":111,"path":112,"stem":113,"icon":114},"Custom Integration","\u002Fframeworks\u002Fcustom-integration","2.frameworks\u002F15.custom-integration","i-lucide-puzzle",{"title":116,"path":117,"stem":118,"children":119,"page":29},"Core Concepts","\u002Fcore-concepts","3.core-concepts",[120,125,130,135,140,145,150,154,159,164,169],{"title":121,"path":122,"stem":123,"icon":124},"Request Lifecycle","\u002Fcore-concepts\u002Flifecycle","3.core-concepts\u002F0.lifecycle","i-lucide-arrow-right-left",{"title":126,"path":127,"stem":128,"icon":129},"Wide Events","\u002Fcore-concepts\u002Fwide-events","3.core-concepts\u002F1.wide-events","i-lucide-layers",{"title":131,"path":132,"stem":133,"icon":134},"Vite Plugin","\u002Fcore-concepts\u002Fvite-plugin","3.core-concepts\u002F10.vite-plugin","i-custom-vite",{"title":136,"path":137,"stem":138,"icon":139},"AI SDK Integration","\u002Fcore-concepts\u002Fai-sdk","3.core-concepts\u002F11.ai-sdk","i-simple-icons-vercel",{"title":141,"path":142,"stem":143,"icon":144},"Structured Errors","\u002Fcore-concepts\u002Fstructured-errors","3.core-concepts\u002F2.structured-errors","i-lucide-shield-alert",{"title":146,"path":147,"stem":148,"icon":149},"Best Practices","\u002Fcore-concepts\u002Fbest-practices","3.core-concepts\u002F3.best-practices","i-lucide-shield-check",{"title":151,"path":152,"stem":153,"icon":104},"Typed Fields","\u002Fcore-concepts\u002Ftyped-fields","3.core-concepts\u002F4.typed-fields",{"title":155,"path":156,"stem":157,"icon":158},"Sampling","\u002Fcore-concepts\u002Fsampling","3.core-concepts\u002F5.sampling","i-lucide-filter",{"title":160,"path":161,"stem":162,"icon":163},"Client Logging","\u002Fcore-concepts\u002Fclient-logging","3.core-concepts\u002F6.client-logging","i-lucide-monitor",{"title":165,"path":166,"stem":167,"icon":168},"Configuration","\u002Fcore-concepts\u002Fconfiguration","3.core-concepts\u002F7.configuration","i-lucide-settings",{"title":170,"path":171,"stem":172,"icon":173},"Performance","\u002Fcore-concepts\u002Fperformance","3.core-concepts\u002F8.performance","i-lucide-gauge",{"title":175,"path":176,"stem":177,"children":178,"page":29},"Adapters","\u002Fadapters","4.adapters",[179,183,188,193,198,203,208,213,218,223,228],{"title":36,"path":180,"stem":181,"icon":182},"\u002Fadapters\u002Foverview","4.adapters\u002F1.overview","i-custom-plug",{"title":184,"path":185,"stem":186,"icon":187},"Pipeline","\u002Fadapters\u002Fpipeline","4.adapters\u002F10.pipeline","i-lucide-workflow",{"title":189,"path":190,"stem":191,"icon":192},"Browser","\u002Fadapters\u002Fbrowser","4.adapters\u002F11.browser","i-lucide-globe",{"title":194,"path":195,"stem":196,"icon":197},"Axiom","\u002Fadapters\u002Faxiom","4.adapters\u002F2.axiom","i-custom-axiom",{"title":199,"path":200,"stem":201,"icon":202},"OTLP","\u002Fadapters\u002Fotlp","4.adapters\u002F3.otlp","i-simple-icons-opentelemetry",{"title":204,"path":205,"stem":206,"icon":207},"PostHog","\u002Fadapters\u002Fposthog","4.adapters\u002F4.posthog","i-simple-icons-posthog",{"title":209,"path":210,"stem":211,"icon":212},"Sentry","\u002Fadapters\u002Fsentry","4.adapters\u002F5.sentry","i-simple-icons-sentry",{"title":214,"path":215,"stem":216,"icon":217},"Better Stack","\u002Fadapters\u002Fbetter-stack","4.adapters\u002F6.better-stack","i-simple-icons-betterstack",{"title":219,"path":220,"stem":221,"icon":222},"File System","\u002Fadapters\u002Ffs","4.adapters\u002F7.fs","i-lucide-hard-drive",{"title":224,"path":225,"stem":226,"icon":227},"HyperDX","\u002Fadapters\u002Fhyperdx","4.adapters\u002F8.hyperdx","i-custom-hyperdx",{"title":229,"path":230,"stem":231,"icon":232},"Custom Adapters","\u002Fadapters\u002Fcustom","4.adapters\u002F9.custom","i-lucide-code",{"title":234,"path":235,"stem":236,"children":237,"page":29},"Enrichers","\u002Fenrichers","5.enrichers",[238,241,245],{"title":36,"path":239,"stem":240,"icon":28},"\u002Fenrichers\u002Foverview","5.enrichers\u002F1.overview",{"title":242,"path":243,"stem":244,"icon":114},"Built-in","\u002Fenrichers\u002Fbuilt-in","5.enrichers\u002F2.built-in",{"title":246,"path":247,"stem":248,"icon":232},"Custom","\u002Fenrichers\u002Fcustom","5.enrichers\u002F3.custom",{"title":250,"path":251,"stem":252,"children":253,"page":29},"NuxtHub","\u002Fnuxthub","6.nuxthub",[254,258],{"title":36,"path":255,"stem":256,"icon":257},"\u002Fnuxthub\u002Foverview","6.nuxthub\u002F1.overview","i-lucide-database",{"title":259,"path":260,"stem":261,"icon":262},"Retention","\u002Fnuxthub\u002Fretention","6.nuxthub\u002F2.retention","i-lucide-clock",{"id":264,"title":25,"body":265,"description":708,"extension":709,"links":710,"meta":718,"navigation":719,"path":26,"seo":720,"stem":27,"__hash__":721},"docs\u002F1.getting-started\u002F4.agent-skills.md",{"type":266,"value":267,"toc":688},"minimark",[268,272,277,286,309,313,358,362,365,368,397,401,406,409,447,451,454,479,483,493,522,526,529,544,555,566,577,588,599,603,611,615,618,622,633,637,648,652,663,667,684],[269,270,271],"p",{},"evlog includes agent skills that help AI assistants review your logging patterns and guide evlog adoption.",[273,274,276],"h2",{"id":275},"what-are-agent-skills","What are Agent Skills?",[269,278,279,285],{},[280,281,25],"a",{"href":282,"rel":283},"https:\u002F\u002Fagentskills.io\u002F",[284],"nofollow"," is an open specification for packaging AI assistant capabilities. Skills provide:",[287,288,289,297,303],"ul",{},[290,291,292,296],"li",{},[293,294,295],"strong",{},"Domain knowledge",": Best practices for wide events and structured errors",[290,298,299,302],{},[293,300,301],{},"Code review",": Identify logging anti-patterns in your codebase",[290,304,305,308],{},[293,306,307],{},"Guided adoption",": Step-by-step help migrating to evlog",[273,310,312],{"id":311},"available-skills","Available Skills",[314,315,316,329],"table",{},[317,318,319],"thead",{},[320,321,322,326],"tr",{},[323,324,325],"th",{},"Skill",[323,327,328],{},"Description",[330,331,332,344],"tbody",{},[320,333,334,341],{},[335,336,337],"td",{},[338,339,340],"code",{},"skills\u002Freview-logging-patterns",[335,342,343],{},"Review code for logging patterns, suggest evlog adoption, guide wide event design",[320,345,346,351],{},[335,347,348],{},[338,349,350],{},"skills\u002Fanalyze-logs",[335,352,353,354,357],{},"Analyze application logs from ",[338,355,356],{},".evlog\u002Flogs\u002F"," to debug errors, investigate performance, and understand behavior",[273,359,361],{"id":360},"installing-the-skill","Installing the Skill",[269,363,364],{},"Compatible agents (Cursor, Claude Code, etc.) can discover and use skills automatically.",[269,366,367],{},"To manually install with the skills CLI:",[369,370,376],"pre",{"className":371,"code":372,"filename":373,"language":374,"meta":375,"style":375},"language-bash shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","npx skills add https:\u002F\u002Fwww.evlog.dev\n","Terminal","bash","",[338,377,378],{"__ignoreMap":375},[379,380,383,387,391,394],"span",{"class":381,"line":382},"line",1,[379,384,386],{"class":385},"sBMFI","npx",[379,388,390],{"class":389},"sfazB"," skills",[379,392,393],{"class":389}," add",[379,395,396],{"class":389}," https:\u002F\u002Fwww.evlog.dev\n",[273,398,400],{"id":399},"what-the-skill-does","What the Skill Does",[402,403,405],"h3",{"id":404},"code-review","Code Review",[269,407,408],{},"The skill analyzes your codebase for:",[287,410,411,425,431,441],{},[290,412,413,416,417,420,421,424],{},[293,414,415],{},"Scattered logging",": Multiple ",[338,418,419],{},"console.log"," or ",[338,422,423],{},"logger.info"," calls in request handlers",[290,426,427,430],{},[293,428,429],{},"Missing context",": Logs without user, request, or business context",[290,432,433,436,437,440],{},[293,434,435],{},"Unhelpful errors",": ",[338,438,439],{},"throw new Error()"," without structured fields",[290,442,443,446],{},[293,444,445],{},"Correlation gaps",": Missing request IDs or trace IDs",[402,448,450],{"id":449},"adoption-guidance","Adoption Guidance",[269,452,453],{},"The skill helps you:",[287,455,456,459,462,476],{},[290,457,458],{},"Convert traditional logging to wide events",[290,460,461],{},"Design effective wide event schemas",[290,463,464,465,468,469,472,473],{},"Implement structured errors with ",[338,466,467],{},"why",", ",[338,470,471],{},"fix",", and ",[338,474,475],{},"link",[290,477,478],{},"Set up evlog in Nuxt, Nitro, or standalone TypeScript",[402,480,482],{"id":481},"log-analysis","Log Analysis",[269,484,485,486,489,490,492],{},"The ",[338,487,488],{},"analyze-logs"," skill teaches your AI assistant to read structured logs from ",[338,491,356],{},":",[287,494,495,501,507,516],{},[290,496,497,500],{},[293,498,499],{},"Error debugging",": Find and explain errors, stack traces, and failure patterns",[290,502,503,506],{},[293,504,505],{},"Performance investigation",": Identify slow requests by duration",[290,508,509,512,513],{},[293,510,511],{},"Request tracing",": Follow a request across its lifecycle using ",[338,514,515],{},"requestId",[290,517,518,521],{},[293,519,520],{},"Pattern detection",": Spot recurring issues or anomalies",[402,523,525],{"id":524},"example-prompts","Example Prompts",[269,527,528],{},"Ask your AI assistant:",[530,531,532],"code-collapse",{},[369,533,538],{"className":534,"code":535,"filename":536,"language":537,"meta":375,"style":375},"language-txt shiki shiki-themes material-theme-lighter material-theme material-theme-palenight","Review this file for logging anti-patterns\n","Prompt","txt",[338,539,540],{"__ignoreMap":375},[379,541,542],{"class":381,"line":382},[379,543,535],{},[530,545,546],{},[369,547,549],{"className":534,"code":548,"filename":536,"language":537,"meta":375,"style":375},"Help me convert these console.log calls to a wide event\n",[338,550,551],{"__ignoreMap":375},[379,552,553],{"class":381,"line":382},[379,554,548],{},[530,556,557],{},[369,558,560],{"className":534,"code":559,"filename":536,"language":537,"meta":375,"style":375},"What context should I add to this wide event?\n",[338,561,562],{"__ignoreMap":375},[379,563,564],{"class":381,"line":382},[379,565,559],{},[530,567,568],{},[369,569,571],{"className":534,"code":570,"filename":536,"language":537,"meta":375,"style":375},"How do I structure this error with evlog?\n",[338,572,573],{"__ignoreMap":375},[379,574,575],{"class":381,"line":382},[379,576,570],{},[530,578,579],{},[369,580,582],{"className":534,"code":581,"filename":536,"language":537,"meta":375,"style":375},"Why is the checkout endpoint failing?\n",[338,583,584],{"__ignoreMap":375},[379,585,586],{"class":381,"line":382},[379,587,581],{},[530,589,590],{},[369,591,593],{"className":534,"code":592,"filename":536,"language":537,"meta":375,"style":375},"Show me the slowest requests from today\n",[338,594,595],{"__ignoreMap":375},[379,596,597],{"class":381,"line":382},[379,598,592],{},[273,600,602],{"id":601},"skill-structure","Skill Structure",[369,604,609],{"className":605,"code":607,"language":608},[606],"language-text","skills\u002F\n├── review-logging-patterns\u002F\n│   ├── SKILL.md              # Main skill instructions\n│   └── references\u002F\n│       ├── wide-events.md    # Wide event patterns\n│       ├── structured-errors.md # Error handling guide\n│       └── code-review.md    # Review checklist\n└── analyze-logs\u002F\n    └── SKILL.md              # Log analysis from .evlog\u002Flogs\u002F\n","text",[338,610,607],{"__ignoreMap":375},[273,612,614],{"id":613},"reference-documents","Reference Documents",[269,616,617],{},"The skill includes reference documents that provide:",[402,619,621],{"id":620},"wide-eventsmd","wide-events.md",[287,623,624,627,630],{},[290,625,626],{},"Wide event anatomy and best practices",[290,628,629],{},"Context grouping patterns",[290,631,632],{},"Output format examples",[402,634,636],{"id":635},"structured-errorsmd","structured-errors.md",[287,638,639,642,645],{},[290,640,641],{},"Error field definitions",[290,643,644],{},"Status code guidelines",[290,646,647],{},"Frontend integration patterns",[402,649,651],{"id":650},"code-reviewmd","code-review.md",[287,653,654,657,660],{},[290,655,656],{},"Checklist for logging code review",[290,658,659],{},"Common anti-patterns to identify",[290,661,662],{},"Migration suggestions",[273,664,666],{"id":665},"next-steps","Next Steps",[287,668,669,674,679],{},[290,670,671,673],{},[280,672,20],{"href":21}," - Get started with evlog",[290,675,676,678],{},[280,677,126],{"href":127}," - Learn wide event design",[290,680,681,683],{},[280,682,141],{"href":142}," - Error handling patterns",[685,686,687],"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);}",{"title":375,"searchDepth":689,"depth":689,"links":690},2,[691,692,693,694,701,702,707],{"id":275,"depth":689,"text":276},{"id":311,"depth":689,"text":312},{"id":360,"depth":689,"text":361},{"id":399,"depth":689,"text":400,"children":695},[696,698,699,700],{"id":404,"depth":697,"text":405},3,{"id":449,"depth":697,"text":450},{"id":481,"depth":697,"text":482},{"id":524,"depth":697,"text":525},{"id":601,"depth":689,"text":602},{"id":613,"depth":689,"text":614,"children":703},[704,705,706],{"id":620,"depth":697,"text":621},{"id":635,"depth":697,"text":636},{"id":650,"depth":697,"text":651},{"id":665,"depth":689,"text":666},"AI-assisted code review and evlog adoption using Agent Skills. Let AI review your logging patterns and guide migration to wide events.","md",[711],{"label":712,"icon":713,"to":714,"target":715,"color":716,"variant":717},"Agent Skills Spec","i-lucide-external-link","https:\u002F\u002Fagentskills.io","_blank","neutral","subtle",{},{"icon":28},{"title":25,"description":708},"Sht_6arWOCWEqDipADp6UxGegi_fGGsie4zkKWt-YEs",[723,725],{"title":20,"path":21,"stem":22,"description":724,"icon":23,"children":-1},"Get up and running with evlog in minutes. Learn useLogger, createError, parseError, and the log API for wide events and structured errors.",{"title":36,"path":37,"stem":38,"description":726,"icon":39,"children":-1},"evlog supports every major TypeScript framework. Choose your stack and get started in minutes.",1775236123350]