storybook-renderer

storybook-renderer

MCP server to query and render the Doggie UI design system's Storybook documentation, enabling component search, URL rendering, and natural language questions.

Category
Visit Server

README

MCP Storybook Render

MCP server en NestJS para consultar el design system Doggie UI y renderizar paginas JS-heavy con Puppeteer.

Este proyecto reemplaza el enfoque anterior basado en Node plano y usa:

  • NestJS
  • arquitectura modular con separacion por dominio/aplicacion/infrastructure
  • MCP moderno por Streamable HTTP
  • logs de auditoria en archivo .log

Que hace este MCP

Expone tools MCP para:

  • renderizar una URL y devolver HTML, texto y screenshot
  • hacer preguntas sobre la documentacion renderizada
  • buscar stories/componentes en Storybook
  • listar el catalogo de stories por seccion

Caso de uso principal:

  • consultar desde VS Code informacion de componentes, tokens y documentacion del design system Doggie UI sin pegar JSON manual cada vez

Estado actual

  • Nombre del servidor MCP: storybook-renderer
  • Transporte recomendado: HTTP
  • Endpoint MCP: http://127.0.0.1:3333/mcp
  • Healthcheck: http://127.0.0.1:3333/health
  • Node validado en este proyecto: 22.19.0

Importante:

  • este proyecto ya no usa SSE legado como transporte principal
  • la conexion correcta en VS Code es type: "http"
  • no depende de mcp-cli.ts

Estructura general

  • src/main.ts: arranque en modo http o stdio
  • src/modules/mcp: servidor MCP, definicion de tools y logging
  • src/modules/renderer: render de paginas con Puppeteer
  • src/modules/storybook: catalogo, busqueda, smart routing y ranking de fragmentos
  • logs/storybook-renderer.log: auditoria de consultas MCP

Instalacion

Desde esta carpeta:

Set-Location "C:\satrack\mcp-storybook-render"
npm install

Como iniciar el proyecto

Modo recomendado, para VS Code conectado por MCP HTTP:

Set-Location "C:\satrack\mcp-storybook-render"
npm run start:http

Verificacion rapida:

Invoke-WebRequest http://127.0.0.1:3333/health | Select-Object -ExpandProperty Content

Debe responder:

{"ok":true}

Modo stdio, solo si en algun momento lo necesitas:

npm run start:stdio

Configuracion en VS Code

En tu mcp.json debe quedar asi:

"storybook-renderer": {
  "type": "http",
  "url": "http://127.0.0.1:3333/mcp",
  "alwaysAllow": ["*"]
}

Importante:

  • no uses transport: "sse" para este proyecto nuevo
  • no uses http://127.0.0.1:3333/sse
  • si VS Code sigue intentando /sse, recarga la ventana con Developer: Reload Window

Tool disponible

storybook_execute

El MCP ahora publica una sola tool. Todas las capacidades se invocan con el parametro obligatorio action.

Acciones disponibles:

  • get_user_info: valida autenticacion o un token puntual
  • query_url: consulta contenido de un componente o documentacion
  • render_url: renderiza una URL y puede devolver html, texto o screenshot
  • storybook_search: busca stories o componentes por termino
  • list_stories: lista el catalogo completo o por seccion
  • report_validation: persiste un unico reporte final con la pregunta exacta y la respuesta final del chat

Parametros comunes mas usados:

  • action obligatorio
  • url
  • question
  • query
  • section
  • source: auto, page, previewFrame
  • waitUntil
  • timeoutMs
  • waitForMs
  • topK
  • maxChars

Regla practica:

  • para responder una pregunta sobre un componente, usa storybook_execute con action: "query_url"
  • si no sabes que story corresponde, usa storybook_execute con action: "storybook_search" o action: "list_stories"
  • antes de cualquier accion autenticada, usa storybook_execute con action: "get_user_info"
  • al final de la conversacion, usa una sola vez storybook_execute con action: "report_validation", project, question y answer
  • en answer debes enviar exactamente el texto final mostrado en el chat, incluyendo Markdown cuando aplique

Flujo recomendado de uso

  1. Inicia el servidor con npm run start:http.
  2. Verifica /health.
  3. Asegura que VS Code tenga el bloque type: "http" apuntando a /mcp.
  4. En un chat nuevo, pega el prompt inicial.
  5. Luego pregunta en lenguaje natural.

Regla practica:

  • si ya sabes la story o quieres respuesta directa, usa storybook_execute con action: "query_url"
  • si no sabes que story corresponde, usa primero storybook_execute con action: "storybook_search" o action: "list_stories"

Prompt inicial recomendado

Usa este prompt al comenzar un chat nuevo:

Usa estas reglas:
- MCP a usar: `storybook-renderer`
- Transporte ya configurado en VS Code: HTTP
- No me pidas JSON manual ni llamadas MCP en bruto; ejecuta tu la tool.
- Usa siempre la tool `storybook_execute`.
- Si la consulta es sobre contenido o descripcion de un componente, usa `action: "query_url"`.
- Cuando ya tengas la respuesta final para el usuario, llama exactamente una vez `action: "report_validation"`.
- En esa llamada final envia solo:
  - `project`: nombre del workspace
  - `question`: la pregunta exacta escrita por el usuario en el chat
  - `answer`: la respuesta final exacta mostrada en el chat
- No infieras la pregunta desde `query`, `summary` o busquedas intermedias.
- No reportes resultados de `storybook_search`, `list_stories` o `query_url` como si fueran la respuesta final.
- Si la respuesta final tiene Markdown, listas o bloques de codigo, envialos tal cual en `answer`.
- URL base por defecto:
  `https://stoportaltest.blob.core.windows.net/doggie-ui-sb/index.html`
- Parametros por defecto para `action: "query_url"`:
  - `source: "auto"`
  - `storybookSmartRouting: true`
  - `waitUntil: "networkidle2"`
  - `timeoutMs: 60000`
  - `waitForMs: 2500`
  - `topK: 8`
  - `maxChars: 250000`
- Si no esta claro que componente corresponde a mi pregunta, usa primero `action: "storybook_search"` o `action: "list_stories"`.
- Si encuentras la story correcta, luego usa `action: "query_url"`.
- Responde en espanol.
- Dame respuestas concretas, claras y resumidas.

A partir de ahora, cuando pregunte cosas como:
- "que dice tooltip"
- "como se usa buddytip"
- "buscame el token de elevacion"
- "que componentes hay en atomos"

asume que debes consultar ese MCP.

Ejemplo de consulta base

El archivo exampleSearch.json contiene la configuracion base recomendada:

{
  "name": "storybook_execute",
  "arguments": {
    "action": "query_url",
    "url": "https://stoportaltest.blob.core.windows.net/doggie-ui-sb/index.html",
    "question": "ESCRIBE_AQUI_TU_PREGUNTA",
    "source": "auto",
    "storybookSmartRouting": true,
    "waitUntil": "networkidle2",
    "timeoutMs": 60000,
    "waitForMs": 2500,
    "topK": 8,
    "maxChars": 250000
  }
}

Ejemplo de reporte final

Cuando ya hayas respondido al usuario en el chat, reporta una sola vez asi:

{
  "name": "storybook_execute",
  "arguments": {
    "action": "report_validation",
    "project": "mcp-storybook-render",
    "question": "¿Como implementar el componente Buddytip?",
    "answer": "Respuesta final exacta mostrada en el chat, incluyendo Markdown si aplica."
  }
}

Logs y auditoria

Cada llamada MCP deja traza en consola y en archivo.

Ruta por defecto:

Que registra:

  • timestamp legible
  • tipo de evento: REQUEST, SUCCESS, ERROR
  • requestId
  • nombre de la tool
  • url
  • question, query o section cuando aplique
  • durationMs

Ejemplo:

2026-03-15 17:09:13.569 [REQUEST] requestId=req-1773612553569-1 name=storybook_execute action=storybook_search url=https://stoportaltest.blob.core.windows.net/doggie-ui-sb/index.html query="chip"
2026-03-15 17:09:14.643 [SUCCESS] requestId=req-1773612553569-1 durationMs=1074 name=storybook_execute action=storybook_search url=https://stoportaltest.blob.core.windows.net/doggie-ui-sb/index.html query="chip"

Si quieres cambiar la ruta del log:

$env:MCP_LOG_FILE="C:\ruta\personalizada\storybook-renderer.log"
npm run start:http

Troubleshooting rapido

VS Code no conecta

Revisa:

  • que el servidor este arriba con npm run start:http
  • que /health responda {"ok":true}
  • que en mcp.json uses type: "http" y /mcp

VS Code sigue intentando /sse

Eso significa que todavia tiene configuracion o estado viejo.

Haz esto:

  • corrige mcp.json
  • reinicia el servidor MCP
  • ejecuta Developer: Reload Window en VS Code

No aparecen logs

Revisa:

  • que el servidor realmente este atendiendo consultas
  • que exista la carpeta logs
  • que no hayas sobrescrito MCP_LOG_FILE con una ruta invalida

El chat no usa el MCP automaticamente

Normalmente pasa por falta de contexto en la conversacion.

Solucion:

  • pega el prompt inicial
  • luego pregunta en lenguaje natural

Comandos utiles

npm run start:http
npm run start:http:dev
npm run start:stdio
npm run build
npm test -- --runInBand

Notas finales

  • este proyecto vive en C:\satrack\mcp-storybook-render
  • si aun tienes una version anterior del renderer en otra carpeta, pueden convivir mientras terminas la migracion
  • si vas a usar solo esta version Nest, evita levantar al mismo tiempo otro renderer en el mismo puerto para no mezclar endpoints y diagnostico

Recommended Servers

playwright-mcp

playwright-mcp

A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.

Official
Featured
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

graphlit-mcp-server

The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.

Official
Featured
TypeScript
Kagi MCP Server

Kagi MCP Server

An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Exa Search

Exa Search

A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.

Official
Featured