agentskills.codes
DE

debug-frontend

Debug the Nuxt 3 admin UI using Playwright MCP for visual inspection, console error analysis, and network request tracing. Use when user says 'UI is broken', 'page not loading', 'frontend bug', 'console errors', 'API call failing in UI', 'component not rendering', 'blank page', 'verify my UI changes

Install

mkdir -p .claude/skills/debug-frontend && curl -L -o skill.zip "https://agentskills.codes/api/skills/download/14711" && unzip -o skill.zip -d .claude/skills/debug-frontend && rm skill.zip

Installs to .claude/skills/debug-frontend

Activation

This is the description your AI agent reads to decide when to run this skill — the better it matches your request, the more reliably it fires.

Debug the Nuxt 3 admin UI using Playwright MCP for visual inspection, console error analysis, and network request tracing. Use when user says 'UI is broken', 'page not loading', 'frontend bug', 'console errors', 'API call failing in UI', 'component not rendering', 'blank page', 'verify my UI changes', or 'check the admin interface'. Do NOT use for static code quality audits (use audit-frontend), backend agent debugging (use debug-agent), or bot platform issues (use debug-bot).
481 chars✓ has a “when” triggerlonger than Claude Code's old 250-char listing cap (fine on current versions)

About this skill

Frontend Debugging Assistant

Debug the Nuxt 3 admin interface visually. Issue description or page URL via $ARGUMENTS.

Prerequisites

The admin UI must be running at http://localhost:3333. If not running:

cd packages/web && pnpm dev

Step 1: Navigate to the Page

Use the Playwright MCP browser_navigate tool to open the page. Common entry points:

  • Dashboard: http://localhost:3333/en
  • Agents: http://localhost:3333/en/service/agents
  • Processes: http://localhost:3333/en/service/processes
  • Threads: http://localhost:3333/en/service/threads
  • Knowledge: http://localhost:3333/en/service/databases
  • Users: http://localhost:3333/en/service/users
  • Roles: http://localhost:3333/en/service/roles

Step 2: Capture Page State

Use these Playwright MCP tools to gather diagnostic information:

  1. browser_snapshot: Get the accessibility tree (DOM structure, interactive elements)
  2. browser_take_screenshot: Visual capture of the current state
  3. browser_console_messages with level: "error": Check for JavaScript errors
  4. browser_network_requests: Inspect API calls (failed requests, wrong payloads)

Step 3: Diagnose Common Issues

API Errors (4xx/5xx)

  1. Check browser_network_requests for failed API calls
  2. Look at the request URL and response status
  3. Cross-reference with SDK functions in packages/web/sdk/client/
  4. Check if the API server is running (curl http://localhost:8000/api/v1/active/docs)

Rendering Issues

  1. Take a screenshot to see the visual state
  2. Use browser_snapshot to check the DOM structure
  3. Look for missing data (composable not returning data)
  4. Check if StructuralColumn has loading: true (blocks child rendering)

Auth/Redirect Issues

  1. Check if redirected to /auth/login
  2. Verify the OIDC plugin is configured: packages/web/plugins/oidc-client.ts
  3. Check middleware/auth.global.ts for route guard logic
  4. In dev mode, fake auth should bypass OIDC

i18n Missing Keys

  1. Look for raw key paths displayed instead of translated text (e.g., agent.title shown literally)
  2. Check locale files: packages/web/i18n/locales/en.yaml
  3. Verify the key exists at the expected path

Component Not Updating

  1. Check Pinia-Colada query keys — mismatched keys prevent cache hits
  2. Verify enabled flag on queries (must be true or a reactive ref)
  3. Check if mutation calls queryCache.invalidateQueries() after success
  4. Use browser_evaluate to inspect Vue component state if needed

Step 4: Interact and Reproduce

Use Playwright MCP to interact with the UI:

  • browser_click: Click buttons, links, menu items
  • browser_type: Fill form fields
  • browser_fill_form: Fill multiple form fields at once
  • browser_select_option: Select dropdown values
  • browser_press_key: Keyboard shortcuts (Escape, Enter, Tab)

Reproduce the issue step by step and capture screenshots at each stage.

Step 5: Trace to Source Code

Once the issue is identified:

  1. Find the page component: packages/web/pages/service/{resource}/
  2. Find composables: packages/web/composables/{resource}/
  3. Find child components: packages/web/components/{Resource}/
  4. Check SDK types: packages/web/sdk/client/

Step 6: Report

Provide a structured report with:

  • What was observed: Screenshot + console errors + failed network requests
  • Root cause: Which file and line is responsible
  • Suggested fix: Specific code change to resolve the issue

Step 7: Verify Fix

After applying the suggested fix, re-run Steps 1-2 to confirm:

  1. Navigate to the same page with browser_navigate
  2. Take a new screenshot with browser_take_screenshot
  3. Check browser_console_messages for remaining errors
  4. Verify browser_network_requests shows successful API calls

Examples

  • /debug-frontend the agents page shows a blank table -- Navigate to agents page, check network requests for API failures, inspect DOM for missing data bindings
  • /debug-frontend console errors on the dashboard -- Open dashboard, capture console errors, trace to source component
  • /debug-frontend verify my changes to the roles page -- Navigate to roles page, take screenshot, check for regressions

Troubleshooting Quick Reference

SymptomLikely CauseWhere to Look
Blank pageJavaScript error blocking renderbrowser_console_messages with level "error"
Spinner never stopsAPI call hanging or query enabled flag is falsebrowser_network_requests + composable enabled prop
401 on API callsAuth not configured for devplugins/oidc-client.ts, check dev mode fake auth
Missing translationsi18n key not in locale filei18n/locales/en.yaml, search for the raw key
Stale data after mutationMissing queryCache.invalidateQueries()Composable mutation onSuccess callback
Component not foundAuto-import name mismatchVerify component file path matches Nuxt auto-import convention

Search skills

Search the agent skills registry